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

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

Patricia Arquette
Patricia Arquette原创
2024-12-31 13:55:08817浏览

How to Efficiently Aggregate a Single Column in PostgreSQL Queries with Multiple Columns?

如何聚合查询中的单个列与多个附加列

在 PostgreSQL 中,聚合单个列同时在查询中包含其他列可能会很麻烦。不过,有可用的解决方案。

对主键使用 Group By

PostgreSQL 9.1 及更高版本简化了该过程。使用 GROUP BY 聚合时,只需包含表的主键即可。因此,如果 foo1 是 tbl1 的主键,则查询可以简化为:

SELECT foo1, foo2, foo3, foo4, foo5, foo6, string_agg(aggregated_field, ', ')
FROM   tbl1
GROUP  BY 1
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 ...

这可确保仅在查询的相关部分进行聚合,从而提高性能。

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

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