>데이터 베이스 >MySQL 튜토리얼 >SQL Server 테이블 열을 행으로 효율적으로 변환하는 방법은 무엇입니까?

SQL Server 테이블 열을 행으로 효율적으로 변환하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-21 19:17:13381검색

How to Efficiently Convert SQL Server Table Columns into Rows?

SQL Server 테이블 열을 행으로 변환

테이블 열을 행으로 변환하는 것은 매우 유용한 데이터 처리 기술입니다. 이 문서에서는 SQL Server에서 이 작업을 수행하는 여러 가지 방법을 설명합니다.

UNPIVOT 기능

UNPIVOT 함수는 명시적으로 열을 행으로 변환하므로 유연한 데이터 재구성이 가능합니다. 예를 들어 예제 테이블 스키마에서 'Indicator1'을 'Indicator150' 열로 변환하려면 다음을 수행하세요.

select id, entityId,
  indicatorname,
  indicatorvalue
from yourtable
unpivot
(
  indicatorvalue
  for indicatorname in (Indicator1, Indicator2, Indicator3)
) unpiv;

CROSS APPLY 및 UNION ALL 사용

또는 CROSS APPLY 및 UNION ALL을 사용하여 여러 하위 쿼리를 결합할 수 있습니다.

select id, entityid,
  indicatorname,
  indicatorvalue
from yourtable
cross apply
(
  select 'Indicator1', Indicator1 union all
  select 'Indicator2', Indicator2 union all
  select 'Indicator3', Indicator3 union all
  select 'Indicator4', Indicator4 
) c (indicatorname, indicatorvalue);

CROSS APPLY 및 VALUES 절 사용

지원되는 SQL Server 버전에서는 CROSS APPLY 및 VALUES 절을 사용할 수 있습니다.

select id, entityid,
  indicatorname,
  indicatorvalue
from yourtable
cross apply
(
  values
  ('Indicator1', Indicator1),
  ('Indicator2', Indicator2),
  ('Indicator3', Indicator3),
  ('Indicator4', Indicator4)
) c (indicatorname, indicatorvalue);

다수의 열에 대한 동적 SQL

풀어야 하는 열 수가 많은 테이블의 경우 동적 SQL을 사용하여 프로그래밍 방식으로 쿼리를 생성하는 것이 좋습니다.

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

select @colsUnpivot 
  = stuff((select ','+quotename(C.column_name)
           from information_schema.columns as C
           where C.table_name = 'yourtable' and
                 C.column_name like 'Indicator%'
           for xml path('')), 1, 1, '')

set @query 
  = 'select id, entityId,
        indicatorname,
        indicatorvalue
     from yourtable
     unpivot
     (
        indicatorvalue
        for indicatorname in ('+ @colsunpivot +')
     ) u'

exec sp_executesql @query;

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

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