访问has_many关系时指定订单和限制的快捷方式?

时间:2008-11-28 22:04:55

标签: ruby-on-rails activerecord

在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个帖子?

3 个答案:

答案 0 :(得分:8)

我在博客模型中有类似的东西:

  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)

答案 1 :(得分:3)

您可以使用帖子模型上的命名范围来执行此操作:

class Post < ActiveRecord::Base
  named_scope :limited, lambda {|*num| {:limit => num.empty? ? DEFAULT_LIMIT : num.first}}
end

这与@Milan报告的utility_scopes基本相似,只不过你只需要在那里做饭。

答案 2 :(得分:1)

你可以使用Ryan Daigle的utility_scopes。在安装之后(它是一个宝石),您将获得一些新的有用范围,例如:

@user.posts.ordered('title ASC').limited(5)

您甚至可以为任何型号设置默认顺序和限制。

相关问题