ホームページ >データベース >mysql チュートリアル >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 サイトの他の関連記事を参照してください。