首頁 >資料庫 >mysql教程 >如何在 PostgreSQL 多列查詢中高效聚合單列?

如何在 PostgreSQL 多列查詢中高效聚合單列?

Patricia Arquette
Patricia Arquette原創
2024-12-31 13:55:08821瀏覽

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