> 데이터 베이스 > MySQL 튜토리얼 > UNPIVOT을 사용하여 동적 SQL Server 열을 행으로 바꾸는 방법은 무엇입니까?

UNPIVOT을 사용하여 동적 SQL Server 열을 행으로 바꾸는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-05 04:39:11
원래의
393명이 탐색했습니다.

How to Transpose Dynamic SQL Server Columns to Rows Using UNPIVOT?

UNPIVOT을 사용하여 동적 SQL Server 열을 행으로 바꾸기

SQL Server에서 UNPIVOT 함수를 사용하면 열을 행으로 바꿀 수 있는데, 이 기술은 종종 피벗 해제라고 합니다. 이는 동적 또는 가변 개수의 열이 있는 데이터로 작업할 때 특히 유용합니다.

예시 시나리오

다음 표1을 고려하세요.

Table1
-----------------------------------------
Id       abc  brt ccc ddq eee fff gga hxx
-----------------------------------------
12345     0    1   0   5   0   2   0   0  
21321     0    0   0   0   0   0   0   0   
33333     2    0   0   0   0   0   0   0   
41414     0    0   0   0   5   0   0   1   
55001     0    0   0   0   0   0   0   2   
60000     0    0   0   0   0   0   0   0 
77777     9    0   3   0   0   0   0   0
로그인 후 복사

목표는 다음보다 큰 값만 고려하여 Table1을 다음 Expected_Result_Table로 피벗 해제하는 것입니다. 0:

Expected_Result_Table
---------------------
Id      Word   Qty>0
---------------------
12345    brt    1
12345    ddq    5
12345    fff    2
33333    abc    2
41414    eee    5
41414    hxx    1
55001    hxx    2
77777    abc    9
77777    ccc    3
로그인 후 복사

UNPIVOT을 사용한 솔루션

UNPIVOT 함수는 여러 열이 있는 테이블을 가져와 두 개의 추가 열이 있는 더 넓은 테이블로 변환합니다. 원본 테이블 열의 데이터가 포함된 " 열과 소스를 식별하는 "이름" 열 열입니다.

SELECT Id,
       name AS Word,
       value AS Qty>0
FROM Table1
UNPIVOT (value FOR name IN (abc, brt, ccc, ddq, eee, fff, gga, hxx)) AS unpvt
WHERE value > 0;
로그인 후 복사

이 쿼리는 예상한 결과를 생성합니다.

위 내용은 UNPIVOT을 사용하여 동적 SQL Server 열을 행으로 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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