A.joins(b: :c)
但我希望 (b: :c) 為 b.left_outer_join(:c)
請問有什么想法嗎?
uj5u.com熱心網友回復:
您可以通過手動附加bLEFT OUTER JOIN 來實作c:
a = A.arel_table
b = B.arel_table
c = C.arel_table
a
.join(b)
.on(a[:id].eq(b[:a_id]))
.join(c, Arel::Nodes::OuterJoin)
.on(b[:id].eq(c[:b_id])).to_sql
這使
SELECT
FROM "a"
INNER JOIN "b" ON "a"."id" = "b"."a_id"
LEFT OUTER JOIN "c" ON "b"."id" = "c"."b_id"
uj5u.com熱心網友回復:
或者...
b = B.arel_table
c = C.arel_table
join_on = b.create_on(b[:c_id].eq(c[:id]))
bc_join = b.create_join(c, join_on, Arel::Nodes::OuterJoin)
result = A.joins(b).joins(bc_join)
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/385770.html
