Maj*_*jiy 0 mysql many-to-many
我有两个 SQL 表,“产品”和“标签”。它们具有 n:m 关系,使用第三个表“product_tags”。
我想使用查询来查找具有多个特定标签的每个产品。例如,查找与标签 1、23 和 54 相关的所有产品。
有没有办法只用一个查询来做到这一点?
您可以使用此解决方案。这将获取包含所有关键字 1、23 和 54 的所有产品:
SELECT a.*
FROM products a
INNER JOIN product_tags b ON a.product_id = b.product_id
WHERE b.tag_id IN (1,23,54)
GROUP BY a.product_id
HAVING COUNT(1) = 3
Run Code Online (Sandbox Code Playgroud)
列表中3的项目数在哪里WHERE IN,因此您可以根据要检查的标签数量进行相应调整。
| 归档时间: |
|
| 查看次数: |
1403 次 |
| 最近记录: |