加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – Rails,scope,OR和join

发布时间:2020-12-17 01:53:03 所属栏目:百科 来源:网络整理
导读:我有一个范围: includes(:countries).where("profiles.sector = :sector OR advices.sector = :sector",:sector = sector) 它产生以下SQL: SELECT `profiles`.* FROM `profiles` INNER JOIN `advices` ON `advices`.`profile_id` = `profiles`.`id` WHERE
我有一个范围:

includes(:countries).where("profiles.sector = :sector OR advices.sector = :sector",:sector => sector)

它产生以下SQL:

SELECT `profiles`.* FROM `profiles` INNER JOIN `advices` ON `advices`.`profile_id` = `profiles`.`id` WHERE (profiles.sector = 'Forestry_paper' OR advices.sector = 'Forestry_paper')

(是的,我的个人资料和我的国家模型中有国家/地区)

不幸的是,OR似乎失败了:

它不会使配置文件只有适当的扇区,但没有相关的建议.思考?

解决方法

您正在进行INNER JOIN,因此需要配置文件具有相应的建议.请尝试以下方法:

Profile
  .joins("LEFT JOIN advices ON advices.profile_id = profiles.id")
  .where("profiles.sector = :sector OR advices.sector = :sector",:sector => sector)

这还包括没有建议的配置文件.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读