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