在 ActiveRecord 模型中访问 has_many 关系时,是否有给出限制和顺序的快捷方式?
例如,这里是我想表达的:
@user.posts(:limit => 5, :order => "title")
与更长的版本相反:
Post.find(:all, :limit => 5, :order => "title", :conditions => ['user_id = ?', @user.id])
我知道您可以直接在 has_many 关系中指定它,但是有没有一种方法可以即时完成,例如在一个页面上显示 10 个帖子,而在另一个页面上只显示 3 个?
最佳答案
我在博客模型中有类似的东西:
has_many :posts, :class_name => "BlogPost", :foreign_key => "owner_id",
:order => "items.published_at desc", :include => [:creator] do
def recent(limit=3)
find(:all, :limit => limit, :order => "items.published_at desc")
end
end
用法:
Blog.posts.recent
或者
Blog.posts.recent(5)
关于ruby-on-rails - 访问 has_many 关系时指定订单和限制的快捷方式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/326764/