ホームページ > データベース > mysql チュートリアル > 複雑な SQL クエリで単一の列を効率的に集計するにはどうすればよいですか?

複雑な SQL クエリで単一の列を効率的に集計するにはどうすればよいですか?

DDD
リリース: 2024-12-25 18:07:20
オリジナル
968 人が閲覧しました

How Can I Efficiently Aggregate a Single Column in Complex SQL Queries?

複雑なクエリでの単一列の集計

多数の列を含むクエリを操作する場合、単一の列を効果的に集計するのが難しい場合があります。 SELECT、GROUP BY、ORDER BY 句にすべてのフィールドを含める従来の方法でも十分ですが、クエリが冗長になる可能性があります。

PostgreSQL 9.1 のより簡単な代替手段

PostgreSQL 9.1 以降を使用する場合は、より簡単なアプローチが存在します。 foo1 を主キーとして指定したため、クエリを次のように単純化できます:

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 ...
ログイン後にコピー

集計と結合を別々に行うことで、クエリの大部分で不必要な集計オーバーヘッドを回避できます。

以上が複雑な SQL クエリで単一の列を効率的に集計するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート