首页 >数据库 >mysql教程 >如何从单个 SQL 查询中获取多个计数?

如何从单个 SQL 查询中获取多个计数?

Patricia Arquette
Patricia Arquette原创
2025-01-20 16:28:10742浏览

How to Get Multiple Counts from a Single SQL Query?

通过一个 SQL 查询高效获取多个计数

数据库查询通常需要根据不同条件检索多个聚合值。 虽然某些方法可能效率低下,但一种简洁的方法使用带有聚合函数的 CASE 语句,有效地模仿缺乏此功能的数据库中的 PIVOT 函数的功能。

具体操作方法如下:

假设您需要按列中的不同值分类的计数。 例如,考虑一个跟踪分销商及其级别(“执行”或“个人”)的表。 以下查询有效地计算各种计数:

<code class="language-sql">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;</code>

此查询执行以下操作:

  • *`COUNT()**: Calculates the total number of rows for eachdistributor_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