如何动态构建一个与两个或多个查询相交的查询?
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
)发布于 2021-10-25 13:14:06
Arel::Nodes::Intersect对象在初始化期间接受两个参数(第一个查询和第二个查询与第一个查询相交)。当您有两个以上的查询希望相交时,处理此问题的最简单方法是使用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)))https://stackoverflow.com/questions/69707867
复制相似问题