我得到了以下habtm关系。
我的模型标签与许多标签组关联。所以我可以有多个包含相同标签的标签组。 我有标签组用户 View ,其中显示了所有标签组,包括该标签组的标签。现在,我为标签组提供了一个特殊选项,名为“黑名单”。如果标记组被标记为黑名单,则该标记组没有用户 View ,并且该标记组的所有标记在可能也包含它们的任何其他标记组 View 中不应可见。 我希望我说得足够清楚,您会看到我的问题。
我现在的问题是:相应的 mysql 查询会是什么样子? 我考虑过两个连接表的交集,但据我所知 mysql 不支持交集..
提前致谢。
最佳答案
SELECT DISTINCT Tag.* FROM taggroups TagGroup
INNER JOIN tag_taggroups TagTagGroup ON TagGroup.id = TagTagGroup.taggroup_id
INNER JOIN ( SELECT t.* FROM
tags t
INNER JOIN
tag_taggroups ttg ON t.id = ttg.tag_id
INNER JOIN taggroups tg ON tg.id = ttg.taggroup_id
GROUP by t.id HAVING max(tg.blacklisted) = 0) AS Tag ON Tag.id = TagTagGroup.tag_id
在 friend 的帮助下解决了:)
关于mysql - HABTM特殊加盟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26887840/