【问题标题】:Arel::Nodes::Intersect dynamic queryArel::Nodes::Intersect 动态查询
【发布时间】:2021-10-25 12:13:25
【问题描述】:
如何构建一个动态地与两个或多个查询相交的查询?
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
)
【问题讨论】:
标签:
ruby-on-rails
activerecord
arel
【解决方案1】:
Arel::Nodes::Intersect 对象在初始化期间采用 2 个参数(第一个查询和与第一个相交的第二个查询)。当您有超过 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)))