집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!