SQL行列转换

None.gif 1 . 行列转换 -- 普通
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   varchar from  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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值