gpt4 book ai didi

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

转载 作者:数据小太阳 更新时间:2023-10-29 07:36:23 24 4
gpt4 key购买 nike

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

在 Rails 3.2.11 中,是否有某种方法可以将两个 Relation 对象“或”并返回另一个 Relation 对象?我是否需要使用诸如 squeel 之类的 gem 来做到这一点?

如果做不到:为什么做不到?我可以对 a|b 产生的数组进行分页而不从数据库中加载每条记录吗?
如果可以做到:谁能写一个例子说明如何做到这一点?

提前致谢。

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

TLDR:问题错了,数组可以分页:)

最佳答案

对于你的问题:我可以在不从数据库加载每条记录的情况下对 a|b 产生的数组进行分页吗?

,您可以对array 进行分页。您只需要在 require 'will_paginate/array' 文件中为 array 使用 paginate。如果你在很多地方使用,那么最好将它添加到 config/initializers 中。及其数组,因此它不会每次(即)查询仅触发一次时从数据库加载每条记录。要加载关联,您可以使用 include 对数组使用 eager load

关于ruby-on-rails - 将两个 ActiveRecord::Relation 与 OR 组合,而不是 AND,返回一个 Relation 而不是一个 Array 以便以后能够分页,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15054524/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com