行列转换
编程技术  /  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];
文章归档
文章标签
友情链接