码迷,mamicode.com
首页 > 数据库 > 详细

SQL-行转列

时间:2015-05-07 10:18:47      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:

SQL-行转列

DECLARE @sql_str NVARCHAR(MAX)

DECLARE @sql_col NVARCHAR(MAX)

DECLARE @tableName SYSNAME --行转列表

DECLARE @groupColumn SYSNAME --分组字段

DECLARE @row2column SYSNAME --行变列的字段

DECLARE @row2columnValue SYSNAME --行变列值的字段

SET @tableName = ‘temp‘

SET @groupColumn = ‘T_UserId‘

SET @row2column = ‘T_ProTitName‘

SET @row2columnValue = ‘T_InfoAnswer‘

 

--从行数据中获取可能存在的列

SET @sql_str = N‘

SELECT @sql_col_out = ISNULL(@sql_col_out + ‘‘,‘‘,‘‘‘‘) + QUOTENAME([‘+@row2column+‘])

    FROM [‘+@tableName+‘] GROUP BY [‘+@row2column+‘]‘

--PRINT @sql_str

EXEC sp_executesql @sql_str,N‘@sql_col_out NVARCHAR(MAX) OUTPUT‘,@sql_col_out=@sql_col OUTPUT

--PRINT @sql_col

 

SET @sql_str = N‘

SELECT * FROM (

    SELECT [‘+@groupColumn+‘],[‘+@row2column+‘],[‘+@row2columnValue+‘] FROM [‘+@tableName+‘]) p PIVOT

    (MAX([‘+@row2columnValue+‘]) FOR [‘+@row2column+‘] IN ( ‘+ @sql_col +‘) ) AS pvt

ORDER BY pvt.[‘+@groupColumn+‘]‘

--PRINT (@sql_str)

EXEC (@sql_str)

SQL-行转列

标签:

原文地址:http://www.cnblogs.com/jinhaoObject/p/4483900.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!