>데이터 베이스 >MySQL 튜토리얼 >SQL Server 2005에서 알 수 없는 수의 열이 있는 데이터를 피벗하는 방법은 무엇입니까?

SQL Server 2005에서 알 수 없는 수의 열이 있는 데이터를 피벗하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-13 07:24:42888검색

How to Pivot Data with an Unknown Number of Columns in SQL Server 2005?

SQL Server 2005에서 알 수 없는 수의 열을 처리하는 피벗 데이터

이 문서에서는 SQL Server 2005에서 알 수 없는 수의 열이 포함된 데이터를 처리할 때 발생하는 문제를 살펴봅니다. 주어진 데이터 세트에는 과제 및 성적을 나타내는 변수 열이 포함되어 있으며 원하는 출력은 과제 및 총 학생 점수에 대한 열이 포함된 피벗 테이블입니다.

SQL Server 2005의 제한으로 인해 이 작업에는 순수 SQL(동적 SQL 없음) 솔루션이 불가능합니다. 제안된 답변에서 언급했듯이 동적 SQL은 현재 데이터를 기반으로 필요한 명령문을 동적으로 생성하는 방법을 제공합니다.

예를 들어 Assignments라는 테이블에 과제 이름과 마감일이 포함되어 있는 경우:

<code class="language-sql">CREATE TABLE Assignments (
  ID int NOT NULL,
  AssignmentName varchar(50) NOT NULL,
  DueDate datetime
);</code>

및 데이터:

<code class="language-sql">INSERT INTO Assignments (ID, AssignmentName, DueDate) VALUES (1, 'Assignment 1', '2023-03-01'), (2, 'Assignment 2', '2023-04-01'), (3, 'Assignment 3', '2023-05-01');</code>

다음 동적 SQL을 사용하여 필요한 출력을 생성할 수 있습니다.

<code class="language-sql">DECLARE @cols AS NVARCHAR(MAX),
        @query AS NVARCHAR(MAX);

SET @cols = (SELECT STUFF((
  SELECT ',[' + AssignmentName + ']'
  FROM Assignments
  FOR XML PATH(''), TYPE
), 1, 1, ''));

SET @query = 'SELECT
  StudentName,
  ' + @cols + ',
  SUM(Grade) OVER (PARTITION BY StudentName) AS Total
FROM
  (SELECT
    StudentName,
    AssignmentName,
    CASE WHEN AssignmentName = ''Total'' THEN NULL ELSE Grade END AS Grade
  FROM
    YourTable) AS t
PIVOT
  (MAX(Grade)
  FOR AssignmentName IN (' + @cols + ')) AS pvt';

EXECUTE(@query);</code>

이렇게 하면 과제 열과 학생 총점이 마감일별로 정렬된 피벗 테이블이 생성됩니다(테이블에 DueDate 열이 있는 경우).

위 내용은 SQL Server 2005에서 알 수 없는 수의 열이 있는 데이터를 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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