SQL行列转换

本文介绍两种SQL技巧:一是将成绩表中的科目与分数从行转换为列;二是将表中的多个子项合并为单一字段中的逗号分隔列表。通过动态SQL和自定义函数实现数据的灵活展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

None.gif1. 行列转换--普通
None.gif

None.gif假设有张学生成绩表(CJ)如下
None.gifName Subject Result
None.gif张三 语文 
80
None.gif张三 数学 
90
None.gif张三 物理 
85
None.gif李四 语文 
85
None.gif李四 数学 
92
None.gif李四 物理 
82
None.gif
None.gif想变成 
None.gif姓名 语文 数学 物理
None.gif张三 
80 90 85
None.gif李四 
85 92 82
None.gif
None.gif
declare @sql varchar(4000)
None.gif
set @sql = 'select Name'
None.gif
select @sql = @sql + ',sum(case Subject when '''+Subject+''' then Result end) ['+Subject+']'
None.gif
from (select distinct Subject from CJ) as a
None.gif
select @sql = @sql+' from CJ group by name'
None.gif
select @sql
None.gif
exec(@sql)
None.gif
None.gif
2. 行列转换--合并
None.gif

None.gif有表A,
None.gifid pid
None.gif
1 1
None.gif
1 2
None.gif
1 3
None.gif
2 1
None.gif
2 2
None.gif
3 1
None.gif如何化成表B:
None.gifid pid
None.gif 
1 1,2,3
None.gif 
2 1,2
None.gif 
3 1
None.gif
None.gif创建一个合并的函数
None.gif
alter function fmerg(@id int)
None.gif
returns varchar(8000)
None.gif
as
None.gif
begin
None.gif
declare @str varchar(8000)
None.gif
set @str=''
None.gif
select @str=@str+','+cast(pid as varcharfrom test where id=@id 
None.gif
set @str=right(@str,len(@str)-1)
None.gif
return(@str)
None.gif
End
None.gif
go
None.gif
None.gif
--调用自定义函数得到结果
None.gif
select  id,dbo.fmerg(id) from test

转载于:https://www.cnblogs.com/yuzhixue/archive/2006/10/20/535057.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值