Sql server SQL中pivot的变化

Sql server SQL中pivot的变化,sql-server,excel,unpivot,Sql Server,Excel,Unpivot,我有一张类似于: +------+----------+----------+----------+----------+ | Name | Subject1 | Subject2 | Subject3 | Subject4 | +------+----------+----------+----------+----------+ | x | 10 | 11 | 12 | 13 | | y | 20 | 21

我有一张类似于:

+------+----------+----------+----------+----------+
| Name | Subject1 | Subject2 | Subject3 | Subject4 |
+------+----------+----------+----------+----------+
| x    |       10 |       11 |       12 |       13 |
| y    |       20 |       21 |       22 |       23 |
| z    |       30 |       31 |       32 |       33 |
+------+----------+----------+----------+----------+
我需要得到一个输出:

Name    Subject     Mark
-------------------------------
x   Subject1    10
x   Subject2    11
x   Subject3    12
x   Subject4    13
y   Subject1    20
y   Subject2    21
y   Subject3    22
y   Subject4    23
z   Subject1    30
z   Subject2    31
z   Subject3    32
z   Subject4    33

我需要一个动态查询,因为列的编号和名称在不同的表中不断变化。每个表中至少有56列。同样,我有5张桌子

这种将多列转换为多行的过程称为。如果您有一个已知值,则可以使用以下值:

select name, subject, mark
from yourtable 
unpivot
(
  mark
  for subject in (Subject1, Subject2, Subject3, Subject4)
) unpiv;

如果需要动态执行此操作,则将使用动态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 <> 'Name'
           for xml path('')), 1, 1, '')

set @query 
  = 'select name, subject, mark
     from yourtable
     unpivot
     (
        mark
        for subject in ('+ @colsunpivot +')
     ) u'

exec sp_executesql @query;


注意:当您取消激活数据列时,数据类型必须相同,因此可能需要对数据进行转换

应该是这样的代码注释。非皮沃函数


你的问题表明你没有努力去解决它-1.
--Initialize variables
DECLARE @Columns VARCHAR(MAX) = ''
DECLARE @UnpivotColumns VARCHAR(MAX) = ''

SELECT @Columns = ',' + @Columns FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'your table'
SELECT @UnpivotColumns = ',' + @UnpivotColumns FROM INFORMATION_SCHEMA.COLUMNS 
WHERE TABLE_NAME = 'your table' AND COLUMN_NAME LIKE 'Subject%'

--Remove first comma
SET @Columns = STUFF(@Columns,1,1,'')
SET @UnpivotColumns = STUFF(@UnpivotColumns,1,1,'')

--Assemble the dynamic query       
DECLARE @qry VARCHAR(Max) = 'SELECT Name, Subject, Mark
FROM 
   (SELECT ' + @Columns + '
   FROM pvt) p
UNPIVOT
   (Mark FOR Subject IN 
      (' + @UnpivotColumns + ')
)AS unpvt;
GO'

--PRINT(@qry)
EXEC (@qry)