ruby-on-rails - 我在使用范围方法吗?
问题描述
在我的电影模型中,我有以下代码。
class Movie < ApplicationRecord
belongs_to :user
has_many :reviews, dependent: :destroy
has_many :users, through: :reviews
validates :title, :description, :movie_length, :director, :rating, presence: true
end
def self.show_order_desc
self.review.order("created_at DESC")
end
我在我的电影控制器显示动作中调用它,在那里我有我对那部电影的评论。
def show
@reviews = show_order_desc
end
这是正确的方法吗?这是一个范围吗?它正在工作,但我有一个评论即将到来,我想确保通过这个功能。
解决方案
我认为您正在尝试按降序获取电影的所有评论created_at
。您可以遵循以下代码。
# app/models/movie.rb
class Movie < ApplicationRecord
belongs_to :user
has_many :reviews, dependent: :destroy
has_many :users, through: :reviews
validates :title, :description, :movie_length, :director, :rating, presence: true
end
# app/models/review.rb
class Review < ApplicationRecord
belongs_to :movie
belongs_to :user
scope :created_desc, -> { order(created_at: :desc) }
end
# app/controllers/movies_controller.rb
class MoviesController < ApplicationController
before_action :find_movie, only: [:show] # you can add other actions also
def show
@reviews = @movie.reviews.created_desc
end
# your other actoins
private
def find_movie
@movie = Movie.find(params[:id])
end
end
在这里,我在Review
模型中添加了一个范围,它将根据您的要求订购评论。现在在show
操作中,我首先获取电影的评论,然后使用针对这些评论的范围以降序排列created_at
。
推荐阅读
- reactjs - 如何修复 ReactJS 中的“预期赋值或函数调用,而是看到表达式”错误
- java - 将草图缩放到不同的分辨率
- amazon-web-services - Amazon Transcibe 的问题
- neo4j - 将 CALL 的最高值返回到子查询中的 db.index.fulltext.queryNodes
- laravel - Laravel 试图在本地而不是在生产中获取非对象作品的属性
- r - R:循环遍历有条件的变量
- blockchain - 如何创建具有特定私钥的帐户?
- uwp - 在 OnNavigatedTo 中调用 FileOpenPicker 仅适用于 PC 上的 Win 10,但不适用于 Win 10 Mobile
- sql - SQL:返回对酒店的无效评论
- pyspark - 如何在 Pyspark 中将两个数据集合并为一个