"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 피벗 함수를 사용하여 SQL Server의 열로 행을 변환하는 방법은 무엇입니까?

피벗 함수를 사용하여 SQL Server의 열로 행을 변환하는 방법은 무엇입니까?

2025-03-22에 게시되었습니다
검색:655

How to Convert Rows to Columns in SQL Server Using the PIVOT Function?

SQL Server

의 피벗 함수를 사용하여 행으로 행을 열로 변환합니다.

질문

SQL Server의 피벗 테이블은 행에서 열로 데이터를 전환하는 강력한 방법을 제공합니다. 그러나 올바른 쿼리를 구축 할 때 사용자는 문제가 발생할 수 있습니다.

해결책

알려진 열 값에 피벗 함수를 사용하십시오 :

사전 정의 된 열 값 (이 경우 몇 주)의 경우 피벗 함수를 직접 사용할 수 있습니다.

select *
from 
(
  select store, week, xCount
  from yt 
) src
pivot
(
  sum(xcount)
  for week in ([1], [2], [3])
) piv;

관점 열 값을 동적으로 생성합니다 :

알 수없는 열 값 (예 : 동적 주)을 처리하려면 동적 SQL과 창 함수의 조합을 사용할 수 있습니다.

DECLARE @cols AS NVARCHAR(MAX),
    @query  AS NVARCHAR(MAX)

select @cols = STUFF((SELECT ','   QUOTENAME(Week) 
                    from yt
                    group by Week
                    order by Week
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')

set @query = 'SELECT store,'   @cols   ' from 
             (
                select store, week, xCount
                from yt
            ) x
            pivot 
            (
                sum(xCount)
                for week in ('   @cols   ')
            ) p '

execute(@query);

결과:

두 방법 모두 동일한 결과를 생성합니다.

|

| | 102 |. | 105 |. | 109 | 87 |
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3