ホームページ > データベース > mysql チュートリアル > PostgreSQL で個別のフィルターを使用して列の集計を簡素化するにはどうすればよいですか?

PostgreSQL で個別のフィルターを使用して列の集計を簡素化するにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-22 17:26:10
オリジナル
883 人が閲覧しました

How Can I Simplify Aggregating Columns with Distinct Filters in PostgreSQL?

PostgreSQL の個別フィルターによる列集計の効率化

次のコードは、複数のテーブルからデータを集計し、個別のフィルターを適用して、プレイされたゲーム、勝ったゲーム、負けたゲームを分類します。機能的ではありますが、その複雑さと長さにより、より効率的なアプローチが必要になります。この記事では、より簡単な方法について説明します。

FILTER 句の利用 (PostgreSQL 9.4 以降)

PostgreSQL 9.4 以降のバージョンでは、標準 SQL FILTER 句が提供され、集計内での動的フィルタリングが可能になります。これにより、クエリが大幅に簡素化されます。

<code class="language-sql">SELECT u.name,
       COUNT(*) FILTER (WHERE g.winner_id > 0) AS played,
       COUNT(*) FILTER (WHERE g.winner_id = u.id) AS won,
       COUNT(*) FILTER (WHERE g.winner_id <> u.id) AS lost
FROM games g
JOIN users u ON u.id IN (g.player_1_id, g.player_2_id)
GROUP BY u.name;</code>
ログイン後にコピー

古い PostgreSQL バージョンの代替

PostgreSQL 9.4 より前のバージョンの場合、集計関数内でブール式を使用する回避策が利用可能です。

<code class="language-sql">SELECT u.name,
       COUNT(g.winner_id > 0 OR NULL) AS played,
       COUNT(g.winner_id = u.id OR NULL) AS won,
       COUNT(g.winner_id <> u.id OR NULL) AS lost
FROM games g
JOIN users u ON u.id IN (g.player_1_id, g.player_2_id)
GROUP BY u.name;</code>
ログイン後にコピー

この方法は、FILTER 句より効率的ではありませんが、古い PostgreSQL インストールに対して実用的なソリューションを提供します。

概要

FILTER 句 (PostgreSQL 9.4) またはブール型の回避策を使用すると、より簡潔で、ほとんどの場合、パフォーマンスの高いソリューションが提供されます。 FILTER 句は、読みやすさと効率性が向上しているため、新しいバージョンでは推奨されるアプローチです。 古いバージョンの場合、ブール値による回避策が依然として有効な代替手段です。

以上がPostgreSQL で個別のフィルターを使用して列の集計を簡素化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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