>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 고유 필터를 사용하여 열 집계를 단순화하려면 어떻게 해야 합니까?

PostgreSQL에서 고유 필터를 사용하여 열 집계를 단순화하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-22 17:26:10927검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.