0

我想转置下表,以便第一列(tabLabel)成为标题。我需要动态地执行此操作,因为行数是未知的。我看过关于动态枢轴的帖子,但我不完全理解如何做到这一点。

tabLabel            documentId  recipientId     Date    value
Street Address          1           1           NULL    123 mockingbird lane
City                    1           1           NULL    city
Patient Phone           1           1           NULL    999-999-9999
Responsible Phone       1           1           NULL    999-999-9999
Gross Income            1           1           NULL    999
Monthly Mortgage/Rent   1           1           NULL    100
Monthly Auto            1           1           NULL    200

最终版本:

Street Address         City   Patient Phone   Responsible Phone   Gross Income  Monthly Mortage/Rent   Monthly Auto   documentId   recipientId   Date
123 mockingbird lane   city   999-999-9999    999-999-9999        999           100                    200            1             1            NULL

选择查询原始表:

SELECT [tabLabel]
  ,[documentId]
  ,[recipientId]
  ,[Date]
  ,[value]
  FROM [zDocusign_Document_Tab_Fields]
4

1 回答 1

3

动态sql

-- Build colums
DECLARE @cols NVARCHAR(MAX)
SELECT  @cols = STUFF((
    SELECT  DISTINCT ',' + QUOTENAME([tabLabel])
    FROM    zDocusign_Document_Tab_Fields
    FOR XML PATH('')
), 1, 1, '')
-- Selecting as FOR XML PATH will give you a string value with all of the fields combined
-- separated by comma.  Stuff simply removes the first comma.
-- Quotename wraps the [tabLabel] value in brackets to allow for spaces in column name
-- You end up with
-- [City],[Gross Income],[Monthly Auto],[Monthly Mortgage/Rent],[Patient Phone],[Responsible Phone],[Street Address]

-- Build sql
DECLARE @sql NVARCHAR(MAX)
SET     @sql = N'
    SELECT  ' + @cols +' 
    FROM    zDocusign_Document_Tab_Fields
    PIVOT   (
        MAX([value])
        FOR [tabLabel] IN (' + @cols + ')
    ) p
'

-- Execute Sql
EXEC(@sql)
于 2016-07-14T20:11:11.137 回答