前端之家收集整理的这篇文章主要介绍了
SQL SELECT与m:n的关系,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在用户和标签之间有m:n的关系.一个用户可以拥有m个标签,一个标签可以属于n个用户.表看起来像这样:
USER:
ID
USER_NAME
USER_HAS_TAG:
USER_ID
TAG_ID
TAG:
ID
TAG_NAME
假设我需要选择所有标签为“apple”,“orange”和“banana”的用户.使用sql(MysqL DB)实现此目的的最有效方法是什么?
最佳答案
除了其他好的答案之外,还可以检查WHERE子句中的条件:
select *
from user u
where 3 = (
select count(distinct t.id)
from user_has_tag uht
inner join tag t on t.id = uht.tag_id
where t.name in ('apple','orange','banana')
and uht.user_id = u.userid
)
计数(不同的……)确保标记只计算一次,即使用户有多个“香蕉”标记.
顺便说一句,该网站fruitoverflow.com尚未注册:)
原文链接:https://www.f2er.com/mysql/433950.html