Arel::Nodes::Intersect动态查询



如何构建一个动态交叉两个或多个查询的查询?

arel = Arel::Nodes::Intersect.new(
Language.where(foreign_key: 1),
Language.where(foreign_key: 2),
...
)

我试过这样做,但它不起作用

keys = [1,2,3]
arel = Arel::Nodes::Intersect.new(
keys.each do |key|
Language.where(foreign_key: key)
end
)

Arel::Nodes::Intersect对象在初始化期间接受2个参数(第一个查询和第二个与第一个相交的查询)。当您希望交叉两个以上的查询时,最简单的处理方法是使用Enumerable#reduce将这些交叉点链接在一起。(Arel::SelectManager还提供了一个称为#intersect的方便方法,其中接收器将用作Arel::Nodes::Intersect的第一个参数)

的例子:

keys = [1,2,3]
scopes = keys.map {|k| Language.where(foreign_key: k).arel }
subquery = scopes.reduce do |memo,scope| 
# Arel::Nodes::Intersect.new(memo,scope)
memo.intersect(scope)
end 
Language.from(Arel::Nodes::As.new(subquery,Arel.sql(Language.arel_table.name)))

相关内容

  • 没有找到相关文章

最新更新