> 데이터 베이스 > MySQL 튜토리얼 > PostgreSQL에서 플레이어 게임 통계를 효율적으로 집계하려면 어떻게 해야 합니까?

PostgreSQL에서 플레이어 게임 통계를 효율적으로 집계하려면 어떻게 해야 합니까?

Linda Hamilton
풀어 주다: 2025-01-22 17:23:11
원래의
892명이 탐색했습니다.

How Can I Efficiently Aggregate Player Game Statistics in PostgreSQL?

플레이어 게임 통계 집계를 위한 PostgreSQL 쿼리 최적화

이 문서에서는 특히 플레이어 이름, 플레이한 게임, 승리한 게임 및 패배한 게임에 초점을 맞춰 PostgreSQL에서 플레이어 게임 통계를 효율적으로 검색하는 방법을 다룹니다. 문제는 플레이어가 player_1 또는 player_2으로 참여할 수 있는 데이터를 통합하는 것입니다. 기존 접근 방식에는 여러 개의 반복적인 쿼리가 포함되는 경우가 많습니다.

간소화된 쿼리 솔루션

PostgreSQL 9.4 이상:

간결하고 읽기 쉬운 코드를 위해 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 버전:

이전 버전과 호환되는 솔루션은 ORNULL을 활용합니다.

<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>
로그인 후 복사

이러한 최적화된 쿼리는 플레이어 통계를 효과적으로 집계하여 중복 쿼리를 방지하고 성능을 향상시킵니다. 적절한 방법을 선택하는 것은 PostgreSQL 버전에 따라 다릅니다.

위 내용은 PostgreSQL에서 플레이어 게임 통계를 효율적으로 집계하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿