SQL SELECT与m:n的关系

tpu*_*nen 5 mysql sql

我在用户和标签之间有m:n的关系.一个用户可以拥有m个标签,一个标签可以属于n个用户.表看起来像这样:

USER:
ID
USER_NAME

USER_HAS_TAG:
USER_ID
TAG_ID

TAG:
ID
TAG_NAME
Run Code Online (Sandbox Code Playgroud)

假设我需要选择所有标签为"apple","orange"和"banana"的用户.使用SQL(MySQL DB)实现此目的的最有效方法是什么?

Qua*_*noi 8

SELECT  u.*
FROM    (
        SELECT  user_id
        FROM    tag t
        JOIN    user_has_tag uht
        ON      uht.tag_id = t.id
        WHERE   tag_name IN ('apple', 'orange', 'banana')
        GROUP BY
                user_id
        HAVING  COUNT(*) = 3
        ) q
JOIN    user u
ON      u.id = q.user_id
Run Code Online (Sandbox Code Playgroud)

通过删除HAVING COUNT(*),你得到OR而不是AND(虽然它不是最有效的方式)

通过替换32,你有精确定义二三标签的用户.

通过替换= 3>= 2,你得到的是有定义的两个至少三个标签的用户.


And*_*mar 4

除了其他好的答案之外,还可以检查 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
)
Run Code Online (Sandbox Code Playgroud)

count(distinct ...)即使用户有多个“香蕉”标签,也可确保标签仅计数一次。

顺便说一句,fruitoverflow.com 网站尚未注册:)