行列转换

编程技术  /  houtizong 发布于 3年前   73

行列转换--普通

 

假设有张学生成绩表(CJ)如下

Name Subject Result

张三 语文     80

张三 数学     90

张三  英语     85

李四 语文     85

李四 数学     92

李四 英语     82

 

想变成

姓名 语文 数学 英语 

张三   80      90       85

李四   85      92       82

--静态sql

select Name,
sum(case when Subject='语文' then Result else 0 end)语文,
sum(case when Subject='数学' then Result else 0 end)数学,
sum(case when Subject='英语' then Result else 0 end)英语
from CJ   group by name

 

--动态sql

declare @sql varchar(max)
set @sql='select Name'
select @sql=@sql+',sum(case when Subject='''+Subject+''' then Result else 0 end)'+Subject from (select distinct Subject from CJ)t
set @sql=@sql+' from CJ  group by Name '
exec(@sql)

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

留言需要登陆哦

技术博客集 - 网站简介:
前后端技术:
后端基于Hyperf2.1框架开发,前端使用Bootstrap可视化布局系统生成

网站主要作用:
1.编程技术分享及讨论交流,内置聊天系统;
2.测试交流框架问题,比如:Hyperf、Laravel、TP、beego;
3.本站数据是基于大数据采集等爬虫技术为基础助力分享知识,如有侵权请发邮件到站长邮箱,站长会尽快处理;
4.站长邮箱:[email protected];

      订阅博客周刊 去订阅

文章归档

文章标签

友情链接

Auther ·HouTiZong
侯体宗的博客
© 2020 zongscan.com
版权所有ICP证 : 粤ICP备20027696号
PHP交流群 也可以扫右边的二维码
侯体宗的博客