加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sqlserver 行转列

发布时间:2020-12-12 12:45:12 所属栏目:MsSql教程 来源:网络整理
导读:--创建测试表 IF ?EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[TestRows2Columns]') AND type in (N'U')) DROP TABLE [dbo].[TestRows2Columns] GO CREATE TABLE [dbo].[TestRows2Columns]( ? ? [Id] [int] IDENTITY(1,1) NOT
--创建测试表
IF ?EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[TestRows2Columns]') AND type in (N'U'))
DROP TABLE [dbo].[TestRows2Columns]
GO
CREATE TABLE [dbo].[TestRows2Columns](
? ? [Id] [int] IDENTITY(1,1) NOT NULL,
? ? [UserName] [nvarchar](50) NULL,
? ? [Subject] [nvarchar](50) NULL,
? ? [Source] [numeric](18,0) NULL
) ON [PRIMARY]
GO


--插入测试数据
INSERT INTO [TestRows2Columns] ([UserName],[Subject],[Source])?
? ? SELECT N'张三',N'语文',60 ?UNION ALL
? ? SELECT N'李四',N'数学',70 ?UNION ALL
? ? SELECT N'王五',N'英语',80 ?UNION ALL
? ? SELECT N'王五',75 ?UNION ALL
? ? SELECT N'王五',57 ?UNION ALL
? ? SELECT N'李四',80 ?UNION ALL
? ? SELECT N'张三',100
GO


SELECT * FROM [TestRows2Columns]


--1:静态拼接行转列
SELECT [UserName],
SUM(CASE [Subject] WHEN '数学' THEN [Source] ELSE 0 END) AS '[数学]',
SUM(CASE [Subject] WHEN '英语' THEN [Source] ELSE 0 END) AS '[英语]',
SUM(CASE [Subject] WHEN '语文' THEN [Source] ELSE 0 END) AS '[语文]' ? ??
FROM [TestRows2Columns]
GROUP BY [UserName]
GO


--2:动态拼接行转列
DECLARE @sql VARCHAR(8000)
SET @sql = 'SELECT [UserName],' ??
SELECT @sql = @sql + 'SUM(CASE [Subject] WHEN '''+[Subject]+''' THEN [Source] ELSE 0 END) AS '''+QUOTENAME([Subject])+''',' ??
FROM (SELECT DISTINCT [Subject] FROM [TestRows2Columns]) AS a ? ??
SELECT @sql = LEFT(@sql,LEN(@sql)-1) + ' FROM [TestRows2Columns] GROUP BY [UserName]' ??
PRINT(@sql)
EXEC(@sql)
GO


--3:静态PIVOT行转列
SELECT ?*
FROM ? ?( SELECT ? ?[UserName],
? ? ? ? ? ? ? ? ? ? [Subject],
? ? ? ? ? ? ? ? ? ? [Source]
? ? ? ? ? FROM ? ? ?[TestRows2Columns]
? ? ? ? ) p PIVOT
( SUM([Source]) FOR [Subject] IN ( [数学],[英语],[语文] ) ) AS pvt
ORDER BY pvt.[UserName];
GO



--4:动态PIVOT行转列
DECLARE @sql_str VARCHAR(8000)
DECLARE @sql_col VARCHAR(8000)
SELECT @sql_col = ISNULL(@sql_col + ',','') + QUOTENAME([Subject]) FROM [TestRows2Columns] GROUP BY [Subject]
SET @sql_str = '
SELECT * FROM (
? ? SELECT [UserName],[Source] FROM [TestRows2Columns]) p PIVOT?
? ? (SUM([Source]) FOR [Subject] IN ( '+ @sql_col +') ) AS pvt?
ORDER BY pvt.[UserName]'
PRINT (@sql_str)
EXEC (@sql_str)


--5:参数化动态PIVOT行转列
-- =============================================
-- Author: ? ? ? ?<听风吹雨>
-- Create date: <2014.05.26>
-- Description: ? ?<参数化动态PIVOT行转列>
-- Blog: ? ? ? ?<http://www.cnblogs.com/gaizai/>
-- =============================================
DECLARE @sql_str NVARCHAR(MAX)
DECLARE @sql_col NVARCHAR(MAX)
DECLARE @tableName SYSNAME --行转列表
DECLARE @groupColumn SYSNAME --分组字段
DECLARE @row2column SYSNAME --行变列的字段
DECLARE @row2columnValue SYSNAME --行变列值的字段
SET @tableName = 'TestRows2Columns'
SET @groupColumn = 'UserName'
SET @row2column = 'Subject'
SET @row2columnValue = 'Source'


--从行数据中获取可能存在的列
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?
? ? (SUM(['+@row2columnValue+']) FOR ['+@row2column+'] IN ( '+ @sql_col +') ) AS pvt?
ORDER BY pvt.['+@groupColumn+']'
--PRINT (@sql_str)
EXEC (@sql_str)



--6:带条件查询的参数化动态PIVOT行转列
-- =============================================
-- Author: ? ? ? ?<听风吹雨>
-- Create date: <2014.05.26>
-- Description: ? ?<参数化动态PIVOT行转列,带条件查询的参数化动态PIVOT行转列>
-- Blog: ? ? ? ?<http://www.cnblogs.com/gaizai/>
-- =============================================
DECLARE @sql_str NVARCHAR(MAX)
DECLARE @sql_col NVARCHAR(MAX)
DECLARE @sql_where NVARCHAR(MAX)
DECLARE @tableName SYSNAME --行转列表
DECLARE @groupColumn SYSNAME --分组字段
DECLARE @row2column SYSNAME --行变列的字段
DECLARE @row2columnValue SYSNAME --行变列值的字段
SET @tableName = 'TestRows2Columns'
SET @groupColumn = 'UserName'
SET @row2column = 'Subject'
SET @row2columnValue = 'Source'
SET @sql_where = 'WHERE UserName = ''王五'''


--从行数据中获取可能存在的列
SET @sql_str = N'
SELECT @sql_col_out = ISNULL(@sql_col_out + '','''') + QUOTENAME(['+@row2column+'])?
? ? FROM ['+@tableName+'] '+@sql_where+' GROUP BY ['+@row2column+']'
--PRINT @sql_str
EXEC sp_executesql @sql_str,['+@row2columnValue+'] FROM ['+@tableName+']'+@sql_where+') p PIVOT?
? ? (SUM(['+@row2columnValue+']) FOR ['+@row2column+'] IN ( '+ @sql_col +') ) AS pvt?
ORDER BY pvt.['+@groupColumn+']'
--PRINT (@sql_str)
EXEC (@sql_str)




http://www.cnblogs.com/gaizai/p/3753296.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读