我有一个带有复杂查询的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')
}
当只有一个用户进行选择时,此功能正常,但如果更多用户选择与当前用户相同的俱乐部,则这些俱乐部仍会显示。如果能够展示出正确的球杆,我还能改进什么?
答案 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')
}