如何从单个 SQL 查询中获取多个计数?
Jan 20, 2025 pm 04:28 PM通过一个 SQL 查询高效获取多个计数
数据库查询通常需要根据不同条件检索多个聚合值。 虽然某些方法可能效率低下,但一种简洁的方法使用带有聚合函数的 CASE
语句,有效地模仿缺乏此功能的数据库中的 PIVOT 函数的功能。
具体操作方法如下:
假设您需要按列中的不同值分类的计数。 例如,考虑一个跟踪分销商及其级别(“执行”或“个人”)的表。 以下查询有效地计算各种计数:
SELECT distributor_id, COUNT(*) AS total_count, SUM(CASE WHEN level = 'exec' THEN 1 ELSE 0 END) AS exec_count, SUM(CASE WHEN level = 'personal' THEN 1 ELSE 0 END) AS personal_count FROM yourtable GROUP BY distributor_id;
登录后复制
此查询执行以下操作:
- *`COUNT()
**: Calculates the total number of rows for each
distributor_id`。 -
SUM(CASE WHEN level = 'exec' THEN 1 ELSE 0 END)
:计算level
为“exec”的行。 如果条件为真,CASE
语句分配 1,否则分配 0。SUM
然后将这些 1 和 0 相加。 -
SUM(CASE WHEN level = 'personal' THEN 1 ELSE 0 END)
:类似地,计算level
为“个人”的行。 -
GROUP BY distributor_id
:对结果进行分组,为每个分发者提供单独的计数。
这个单个查询有效地返回每个 distributor_id
的总计数以及“exec”和“personal”级别的单独计数,所有这些都在单个结果集中。 这种方法比运行多个单独的查询要高效得多。
以上是如何从单个 SQL 查询中获取多个计数?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章
击败分裂小说需要多长时间?
3 周前
By DDD
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章
击败分裂小说需要多长时间?
3 周前
By DDD
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章标签

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器)
