当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《访问has_many关系时指定订单和限制的快捷方式?》经验,为你挑选了1个好方法。

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



1> Dustin..:

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

  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)

推荐阅读
家具销售_903
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有