>데이터 베이스 >MySQL 튜토리얼 >보고용 데이터를 재구성하기 위해 T-SQL에서 여러 열을 피벗하는 방법은 무엇입니까?

보고용 데이터를 재구성하기 위해 T-SQL에서 여러 열을 피벗하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-05 09:52:43253검색

How to Pivot Multiple Columns in T-SQL to Reshape Data for Reporting?

TSQL에서 여러 열 피벗

관계형 데이터베이스로 작업할 때 보고 목적으로 데이터를 재구성해야 하는 경우가 많습니다. 피벗(Pivoting)은 데이터를 행 중심 구조에서 열 중심 구조로 변환하는 데 사용할 수 있는 기술입니다. 이 문서에서는 관련 레이블을 모두 유지하면서 테이블의 여러 열을 피벗하는 방법을 보여줍니다.

과제

GRAND_TOTALS라는 이름의 다음 테이블을 고려해 보세요.

RATIO RESULT SCORE GRADE
Current Ratio 1.294 60 Good
Gearing Ratio 0.3384 70 Good
Performance Ratio 0.0427 50 Satisfactory
TOTAL NULL 180 Good

목표는 RESULT, SCORE 및 GRADE 열을 피벗하여 다음과 같은 테이블을 만드는 것입니다. 형식:

RATIO Current Ratio Gearing Ratio Performance Ratio TOTAL
Result 1.294 0.3384 0.0427 NULL
Score 60 70 50 180
Grade Good Good Satisfactory Good

해결책

여러 열을 효과적으로 피벗하려면 다음 단계를 고려하세요.

  1. 결과, 점수 및 성적 피벗 해제 열:

    피벗 해제에는 여러 열 변환이 포함됩니다. 원래 열 이름을 추적하면서 단일 열로 묶습니다. 이는 UNPIVOT 절을 사용하여 달성할 수 있습니다. 아래 구문은 열 피벗을 해제하는 방법을 보여줍니다.

    select ratio, col, value
    from GRAND_TOTALS
    cross apply
    (
      select 'result', cast(result as varchar(10)) union all
      select 'score', cast(score as varchar(10)) union all
      select 'grade', grade
    ) c(col, value)

    이 쿼리는 RATIO, COL 및 VALUE 열이 있는 새 테이블을 생성합니다. 여기서 COL은 원래 열 이름(결과, 점수 또는 등급)을 나타냅니다. ) 및 VALUE에는 해당 값이 포함됩니다.

  2. PIVOT 적용 기능:

    데이터 피벗이 해제되면 PIVOT 기능을 적용하여 데이터를 원하는 형식으로 변환할 수 있습니다. 피벗 구문은 다음과 같습니다.

    select ratio = col,
      [current ratio], [gearing ratio], [performance ratio], total
    from
    (
      select ratio, col, value
      from GRAND_TOTALS
      cross apply
      (
        select 'result', cast(result as varchar(10)) union all
        select 'score', cast(score as varchar(10)) union all
        select 'grade', grade
      ) c(col, value)
    ) d
    pivot
    (
      max(value)
      for ratio in ([current ratio], [gearing ratio], [performance ratio], total)
    ) piv;

    이 쿼리에서 PIVOT 함수는 RATIO 열을 기준으로 행을 그룹화하고 COL 값을 열 머리글로 사용하여 데이터를 피벗합니다. MAX 집계 함수는 각 행의 최신 값을 검색하는 데 사용됩니다.

결과

위 쿼리를 실행하면 원하는 피벗 테이블이 생성됩니다. :

RATIO Current Ratio Gearing Ratio Performance Ratio TOTAL
grade Good Good Satisfactory Good
result 1.29400 0.33840 0.04270 NULL
score 60.00000 70.00000 50.00000 180.00000

이 테이블은 필요한 모든 레이블을 유지하고 원하는 열을 성공적으로 피벗합니다.

위 내용은 보고용 데이터를 재구성하기 위해 T-SQL에서 여러 열을 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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