首页 >数据库 >mysql教程 >如何在多列查询中高效聚合单列?

如何在多列查询中高效聚合单列?

Barbara Streisand
Barbara Streisand原创
2024-12-20 07:46:10937浏览

How Can I Efficiently Aggregate a Single Column in a Multi-Column Query?

聚合多列查询中的单列

概述

将查询中的单个列与许多其他列聚合可能是一个挑战,尤其是当所有 SELECT 和 ORDER BY 字段必须聚合或属于 GROUP BY 时。这种冗长的查询结构管理起来很麻烦。

PostgreSQL 9.1 的简​​化查询

在 PostgreSQL 9.1 或更高版本中,存在更简单的解决方案。当使用主键作为 GROUP BY 条件时,可以简化查询:

SELECT foo1, foo2, foo3, foo4, foo5, foo6, string_agg(aggregated_field, ', ')
FROM tbl1
GROUP BY 1  -- Group by primary key (foo1)
ORDER BY foo7, foo8;

多表查询

对于涉及不同关系的多个表的查询,先聚合数据会更高效稍后再连接表:

SELECT t1.foo1, t1.foo2, ...,
     t2.bar1, t2.bar2, ...,
     a.aggregated_col
FROM tbl1 t1
LEFT JOIN tbl2 t2 ON ...
...
LEFT JOIN (
   SELECT some_id, string_agg(agg_col, ', ') AS aggregated_col
   FROM agg_tbl a ON ...
   GROUP BY some_id
   ) a ON a.some_id = ?.some_id
ORDER BY ...

通过分离聚合和连接,大部分查询可以避免不必要的聚合,降低复杂度并提高表演。

以上是如何在多列查询中高效聚合单列?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn