首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Arel::Nodes::Intersect动态查询

Arel::Nodes::Intersect动态查询
EN

Stack Overflow用户
提问于 2021-10-25 12:13:26
回答 1查看 42关注 0票数 0

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

代码语言:javascript
复制
arel = Arel::Nodes::Intersect.new(
 Language.where(foreign_key: 1),
 Language.where(foreign_key: 2),
 ...
)

我试过这样的方法,但不起作用

代码语言:javascript
复制
keys = [1,2,3]
arel = Arel::Nodes::Intersect.new(
 keys.each do |key|
   Language.where(foreign_key: key)
 end
)
EN

回答 1

Stack Overflow用户

发布于 2021-10-25 13:14:06

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

示例:

代码语言:javascript
复制
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)))
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69707867

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档