我们有“主题 – 关系 – 类别”.
也就是说,主题通过关系有很多类别.
#Relationship Model Topic_id: integer Category_id: integer @topics=Topic.joins(:relationships)
但是,并非每个主题都有一个类别.那么我们如何检索没有类别的主题呢?
是否有减号查询?
也许它看起来像@ topics = Topic.where(‘id NOT IN(?)’,Relationship.all)
我在activerecord equivalent to SQL ‘minus’找到它但不确定这个解决方案.
解决方法
真的,作为一种关系会更好.认为这样可行:
@topics = Topic.joins('left join relationships on relationships.topic_id = topics.id').where('relationships.category_id is null')
或这个:
@topics = Topic .joins('left join relationships on relationships.topic_id = topics.id join categories on categories.id = relationships.category_id') .group('topics.id').having('count(categories.id) = 0')
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。