通过一个 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>
此查询执行以下操作:
**: 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中文网其他相关文章!