sql - Arel:使用符号的左外连接

标签 sql ruby-on-rails-3 activerecord arel

我有这个用例,我从某个模型中获得符号化的深层关联,并且我必须执行某些涉及使用外连接的查询。如何在不求助于手动编写完整 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!!

为什么这不起作用超出我的范围。我不知道到底缺少什么。但它是我现在拥有的最接近解决方案的方法。如果有人可以帮助我完成我的示例,或者为我提供一个很好的解决方法,或者告诉我 Rails 何时会包含这样一个明显必要的特性,我将永远感激不尽。

最佳答案

这是一个老问题,但为了任何通过搜索引擎找到它的人的利益:

如果你想要什么,你可以输入 .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/

相关文章:

sql - GROUP BY 整数值的区间

ruby-on-rails - 使用事件记录回调来更新模型属性

c++ - 从源代码中使用 SQL lite - 如何创建数据库文件并将一些数据放入其中?

mysql - 如何在sql中以列方式获取行?

ruby-on-rails - 用户 has_many 关联不起作用(错误 :Could not find the association :user_categories in model Category)

ruby-on-rails-3 - cancan Skip_authorization_check 用于设计身份验证

ruby-on-rails - 将模块与 attr_accessible、has_one、has_many 混合

ruby - ActiveRecord - 未定义的方法 'match'

sql - rails : How to fetch records that are 2 'has_many' levels deep?

sql - 获取与其他行中列值相关的列值