我有一个Rails应用程序,它有一个似乎无法解决的复杂查询。我有两张桌子,俱乐部和选择。桌上的俱乐部就像这样:
id,name
1,A
2,B
3,C
4,DTable selections包含所有用户从table中选择的俱乐部:
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')
}当只有一个用户进行选择时,这很好用,但是如果更多的用户选择了与当前用户相同的俱乐部,这些俱乐部仍然会出现。我可以改进什么来显示正确的俱乐部?
发布于 2013-06-21 02:28:51
我找到了一个似乎有效的解决方案,但我不知道它是否是最优雅的:
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')
}https://stackoverflow.com/questions/17220459
复制相似问题