ruby-on-rails – 如何使用Rails ActiveRecord进行LEFT OUTER JOIN?




我没有任何想法你可以给我任何线索(如参考网站).任何帮助将不胜感激.
Model1: GROUP(id,name)
Model2: USER_GROUP_CMB(id,user_id,group_id)

预期的sql语句:

SELECT * 
FROM groups AS g LEFT OUTER JOIN user_group_cmbs AS cmb 
            ON g.id = cmb.group_id
WHERE cmb.user_id = 1

我试图在下面设置协会,但我不知道该做什么.

class Group < ActiveRecord::Base
  has_many :user_group_cmb
end

class UserGroupCmb < ActiveRecord::Base
  has_many :group
end

Rails版本:3.1.1

解决方法

我相信一个包含将使用一个LEFT OUTER JOIN查询,如果您在表中使用包含关联使用的条件:
Group.includes(:user_group_cmb).where("user_group_cmbs.user_id = ?",1)

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...