草庐IT

SQL SELECT 与 m :n relationship

coder 2023-10-04 原文

我在用户和标签之间有 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) 实现此目的的最有效方法是什么?

最佳答案

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

通过删除 HAVING COUNT(*),您将得到 OR 而不是 AND(尽管这不是最有效的方法)

通过将 3 替换为 2,您将获得恰好定义了三个标签中的两个标签的用户。

通过将 = 3 替换为 >= 2,您可以让用户至少定义三个标签中的两个。

关于SQL SELECT 与 m :n relationship,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1680855/

有关SQL SELECT 与 m :n relationship的更多相关文章

随机推荐