ホームページ >データベース >mysql チュートリアル >PostgreSQL で条件付きの出現を効率的にカウントするにはどうすればよいですか?

PostgreSQL で条件付きの出現を効率的にカウントするにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2025-01-24 06:21:10396ブラウズ

How Can I Efficiently Count Conditional Occurrences in PostgreSQL?

PostgreSQL の条件カウント: 最適化方法

データベース テーブル内のデータの出現をカウントする場合、条件ステートメントが長くなることがあります。幸いなことに、PostgreSQL は便利で効率的なソリューションを提供します。

FILTER 集計オプション

PostgreSQL 9.4 以降の場合、最高の効率を得るために FILTER 集計オプションを利用してください:

<code class="language-sql">SELECT category
     , count(*) FILTER (WHERE question1 = 0) AS zero
     , count(*) FILTER (WHERE question1 = 1) AS one
     , count(*) FILTER (WHERE question1 = 2) AS two
FROM   reviews
GROUP  BY 1;</code>

簡潔な構文

シンプルさを優先する場合:

<code class="language-sql">SELECT category
     , count(question1 = 0 OR NULL) AS zero
     , count(question1 = 1 OR NULL) AS one
     , count(question1 = 2 OR NULL) AS two
FROM   reviews
GROUP  BY 1;</code>

クロス集計クエリ

大規模なオプション リストを処理し、より高いパフォーマンスを追求するには、crosstab() 関数の使用を検討してください。

<code class="language-sql">SELECT * FROM crosstab(
     'SELECT category, question1, count(*) AS ct
      FROM   reviews
      GROUP  BY 1, 2
      ORDER  BY 1, 2'
   , 'VALUES (0), (1), (2)'
   ) AS ct (category text, zero int, one int, two int);</code>

以上がPostgreSQL で条件付きの出現を効率的にカウントするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。