我有以下habtm关系。
我的模型标记与许多标记组相关联。所以我可以有多个包含相同标签的标签组。 我有标记组用户视图,其中显示了此标记组的所有标记。现在有一个特殊的选项,我已经为标签组,名为"黑名单"。如果标记组被标记为黑名单,则此标记组没有用户视图,并且此标记组的所有标记都不应在任何其他标记组视图中可见,其中也可能包含它们。 我希望很清楚,你会看到我的问题。
我现在的问题是:相应的mysql查询怎么样? 我想到了两个连接表的交集,但据我所知,mysql不支持交叉点..
提前致谢。
答案 0 :(得分:0)
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
用朋友帮忙解决:)