如何构建一个动态交叉两个或多个查询的查询?
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)))