将两个ActiveRecord :: Relation与OR组合,而不是AND,返回一个Relation而不是一个Array,以便以后能够分页

时间:2013-02-24 17:40:43

标签: ruby-on-rails ruby activerecord will-paginate relation

ab是ActiveRecord :: Relation对象,它们返回相同类型的对象(在本例中为Micropost对象)

a.class
=> ActiveRecord::Relation
b.class
=> ActiveRecord::Relation
a.first
=> Micropost(...) 
b.first
=> Micropost(...) #They both return the same type of objects
c=a+b
c.class
=> Array #This is not what i'm looking for
c=a|b
c.class
=> Array #Not what i'm looking for either
c=(a or b)
c.class
=> ActiveRecord::Relation #But it is just a, so it's wrong
c==a
=> true
a.merge(b)
=> []  #It merges with AND which in my case results in an empty array

是否有某种方法可以“管理”两个Relation对象并在Rails 3.2.11中返回另一个Relation对象?我是否需要使用squeel这样的宝石来做它?

如果无法完成:为什么不能这样做?我可以在不加载数据库中的每条记录的情况下对a|b生成的数组进行分页吗? 如果可以的话:有人可以写一个如何做的例子吗?

提前致谢。

编辑:我将错误的变量复制到代码块中,b不是ActiveRecord :: Relation,它实际上是一个数组,这就是a.merge(b)返回[]的原因。 我的错。

TLDR:问题是错误的,数组可以分页:)

1 个答案:

答案 0 :(得分:2)

对于你的问题:Can I paginate the array resulting from a|b without loading every record from the database?

,您可以对array进行分页。只有您需要require 'will_paginate/array'文件才能使用paginate array。如果您在许多地方使用,那么最好在config/initializers中添加它。并且它的数组每次都不会从数据库加载每条记录(即)查询只被触发一次。要加载关联,您可以使用eager load on array include