首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >复杂的左外部连接查询

复杂的左外部连接查询
EN

Stack Overflow用户
提问于 2013-06-21 01:53:03
回答 1查看 394关注 0票数 0

我有一个Rails应用程序,它有一个似乎无法解决的复杂查询。我有两张桌子,俱乐部和选择。桌上的俱乐部就像这样:

代码语言:javascript
复制
id,name
1,A
2,B
3,C
4,D

Table selections包含所有用户从table中选择的俱乐部:

代码语言:javascript
复制
id,club_id,user_id
1,1,1
2,1,2
3,2,3
4,3,1
5,3,3

现在,我想要一个选择框,其中包含来自餐桌俱乐部的所有项目,而不是当前用户已经选择的元素(他不能选择同一俱乐部两次)。因此,对于用户1,它应该只显示俱乐部B和D,因为他已经选择了A和C。

所以我在模型中创建了一个作用域:

代码语言:javascript
复制
  scope :selectable, ->(current_user) {
    joins('LEFT OUTER JOIN selections ON selections.club_id = clubs.id').
    where('selections.id IS NULL OR selections.user_id != ?', current_user.id).
    group('clubs.id')
  }

当只有一个用户进行选择时,这很好用,但是如果更多的用户选择了与当前用户相同的俱乐部,这些俱乐部仍然会出现。我可以改进什么来显示正确的俱乐部?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-21 02:28:51

我找到了一个似乎有效的解决方案,但我不知道它是否是最优雅的:

代码语言:javascript
复制
  scope :selectable, ->(current_user) {
    joins('LEFT OUTER JOIN selections ON selections.club_id = clubs.id').
    where('selections.id IS NULL OR selections.user_id != ?', current_user.id).
    where('clubs.id NOT IN (?)', current_user.clubs).
    group('clubs.id')
  }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17220459

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档