oracle pivot动态sql,参数化动态PIVOT行转列

本文介绍了如何在SQL Server 2005及以上版本中,使用动态SQL实现行数据到列的数据转换,通过PIVOT操作将'UserName'字段的值按'Subject'字段分组并计算'Source'字段的总和,适用于处理多维度数据汇总。
摘要由CSDN通过智能技术生成

--创建测试表

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'王五',N'数学',75  UNION ALL

SELECT N'王五',N'语文',57  UNION ALL

SELECT N'李四',N'语文',80  UNION ALL

SELECT N'张三',N'英语',100

GO

SELECT * FROM [TestRows2Columns]

--SQLserver 2005及以上

-- =============================================

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)

eda84ecc2659e8c5bb16d9d479fdb661.png

7b5eed9009ce4de2e8c8ee7e22521e4a.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值