>데이터 베이스 >MySQL 튜토리얼 >SQL에서 크로스탭 쿼리를 효율적으로 수행하는 방법은 무엇입니까?

SQL에서 크로스탭 쿼리를 효율적으로 수행하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-20 22:23:11366검색

How to Efficiently Perform a Crosstab Query in SQL?

CASE 및 GROUP BY를 사용하여 PIVOT을 동적으로 교체

질문:

아래 표의 데이터는 행과 열로 구성되어 있습니다. 목표는 이것을 동적 개수의 열이 있는 테이블로 변환하는 것입니다. 여기서 각 열은 지정된 범주별로 그룹화된 값을 나타냅니다.

id feh bar
1 10 A
2 20 A
3 3 B
4 4 B
5 5 C
6 6 D
7 7 D
8 8 D

예상 출력:

bar val1 val2 val3
A 10 20
B 3 4
C 5
D 6 7 8

원래 쿼리:

다음 쿼리는 CASE 표현식과 GROUP BY를 사용하여 원하는 결과를 얻습니다.

<code class="language-sql">SELECT bar, 
MAX(CASE WHEN abc."row" = 1 THEN feh ELSE NULL END) AS "val1",
MAX(CASE WHEN abc."row" = 2 THEN feh ELSE NULL END) AS "val2",
MAX(CASE WHEN abc."row" = 3 THEN feh ELSE NULL END) AS "val3"
FROM
(
  SELECT bar, feh, row_number() OVER (partition by bar) as row
  FROM "Foo"
 ) abc
GROUP BY bar </code>

효율적인 크로스탭 대안:

효율성과 가독성을 높이기 위해 tablefunc 모듈의 크로스탭 기능을 사용하여 동적 솔루션을 구현할 수 있습니다. 예는 다음과 같습니다.

<code class="language-sql">SELECT * FROM crosstab(
  'SELECT bar, 1 AS cat, feh
   FROM tbl_org
   ORDER BY bar, feh')
 AS ct (bar text, val1 int, val2 int, val3 int);  -- 更多列?</code>

여러 값 처리:

동일 카테고리에 여러 값이 있는 시나리오의 경우 크로스탭 기능을 다음과 같은 형태로 확장할 수 있습니다.

<code class="language-sql">SELECT * FROM crosstab(
  'SELECT bar, val, feh
   FROM tbl_org
   ORDER BY 1, 2')
 AS ct (bar text, val1 int, val2 int, val3 int);  -- 更多列?</code>

내장 크로스탭 기능:

tablefunc 모듈은 특정 수의 열에 대해 사전 정의된 크로스탭 기능도 제공합니다.

<code class="language-sql">SELECT * FROM crosstab3('SELECT row_name, attrib, val FROM tbl ORDER BY 1,2');</code>

이러한 기능을 사용하면 호출이 더 간단해지고 기본적으로 텍스트 데이터를 처리할 수 있습니다.

동적 반환 유형:

tablefunc은 프로세스를 단순화하지만 동적 반환 유형을 처리하는 데에는 한계가 있습니다. 이 문제를 해결하기 위해 PL/pgSQL 함수를 사용하거나 동적 SQL 문을 생성하는 등 다른 방법을 고려할 수 있습니다.

위 내용은 SQL에서 크로스탭 쿼리를 효율적으로 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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