如何在MySQL中选择属于多个类别的项目?

Patricia Arquette
发布: 2024-10-31 22:02:02
原创
323 人浏览过

How to Select Items Belonging to Multiple Categories in MySQL?

使用 MySQL 在数据库列中选择多个值匹配

问题:

您有一个关联表,其中的项目可以属于多个类别。如何只选择属于一组指定类别的项目?

解决方案:

要选择满足列的多个特定值的项目,有MySQL 中的两种主要方法:

自连接方法:

此方法在一个连接操作中比较同一个表中的多行。例如,要选择类别 201 和 202 中的项目:

SELECT c1.item_id
FROM item_category AS c1
INNER JOIN item_category AS c2 ON c1.item_id = c2.item_id
WHERE c1.category_id = 201 AND c2.category_id = 202
登录后复制

GROUP BY 方法:

此方法按列对行进行分组并使用 COUNT()聚合以验证某个项目是否属于所有指定类别。例如,要选择类别 201 和 202 中的项目:

SELECT c.item_id, COUNT(*) AS cat_count
FROM item_category AS c
WHERE c.category_id IN (201,202)
GROUP BY c.item_id
HAVING cat_count = 2
登录后复制

这两种方法之间的选择取决于您要搜索的类别数量和性能考虑。

以上是如何在MySQL中选择属于多个类别的项目?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!