HABTM特别加入

时间:2014-11-12 13:12:16

标签: mysql join has-and-belongs-to-many

我有以下habtm关系。

我的模型标记与许多标记组相关联。所以我可以有多个包含相同标签的标签组。 我有标记组用户视图,其中显示了此标记组的所有标记。现在有一个特殊的选项,我已经为标签组,名为"黑名单"。如果标记组被标记为黑名单,则此标记组没有用户视图,并且此标记组的所有标记都不应在任何其他标记组视图中可见,其中也可能包含它们。 我希望很清楚,你会看到我的问题。

我现在的问题是:相应的mysql查询怎么样? 我想到了两个连接表的交集,但据我所知,mysql不支持交叉点..

提前致谢。

1 个答案:

答案 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

用朋友帮忙解决:)