复杂的左外连接查询

时间:2013-06-20 17:53:03

标签: sql ruby-on-rails-3

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

id,name
1,A
2,B
3,C
4,D

表格选择包含所有用户从表俱乐部中选择的俱乐部:

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.

所以我在模型中创建了这个范围:

  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')
  }

当只有一个用户进行选择时,此功能正常,但如果更多用户选择与当前用户相同的俱乐部,则这些俱乐部仍会显示。如果能够展示出正确的球杆,我还能改进什么?

1 个答案:

答案 0 :(得分:1)

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

  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')
  }