- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这个用例,我从某个模型中获得符号化的深层关联,并且我必须执行某些涉及使用外连接的查询。如何在不求助于手动编写完整 SQL 的情况下做到这一点?
我不想要的答案:
- 使用包含(不能很好地解决深层关联( .includes(:cars => [:windows, :engine => [:ignition]..... 工作意外),我不想要它的副作用)
- 自己编写 SQL(抱歉,它是 2013 年的,跨数据库支持等等......,我获取的对象是只读的,更多的副作用)
我想要一个 Arel 解决方案。我知道使用模型中的 arel_table 可以构建 SQL 表达式,还有用于连接的 DSL,但不知何故我无法在模型的连接方法中使用它:
car = Car.arel_table
engine = Engine.arel_table
eng_exp = car.join(engine).on(car[:engine_id].eq(engine[:id]))
eng_exp.to_sql #=> GOOD! very nice!
Car.joins(eng_exp) #=> Breaks!!
最佳答案
这是一个老问题,但为了任何通过搜索引擎找到它的人的利益:
如果你想要什么,你可以输入 .joins
,您可以使用 .create_join
和 .create_on
:
join_on = car.create_on(car[:engine_id].eq(engine[:id]))
eng_join = car.create_join(engine, join_on, Arel::Nodes::OuterJoin)
Car.joins(eng_join)
.join_sources
从您构造的连接对象:
eng_exp = car.join(engine, Arel::Nodes::OuterJoin).on(car[:engine_id].eq(engine[:id]))
Car.joins(eng_exp.join_sources)
关于sql - Arel:使用符号的左外连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15029652/
我知道除了知道什么是“最喜欢的编程卡通”之外,stackoverflow 会对我有所帮助:P 这是接受的答案: Bill Karwin 感谢大家的帮助(我想给你们加倍投票) 我的查询结果是这样的(这是
我查询了此查询,该查询将相关图像返回到评论 return $comments = \DB::table('comments')->select('comments.comment','com
如果没有任何地址(内部连接),我有以下 LINQ 返回零。我如何将其设为 Outer Join 然后仅 Take(1)? var results = query.Join(
我是一名优秀的程序员,十分优秀!