牛骨文教育服务平台(让学习变的简单)
博文笔记

SQL一维数据转二维

创建时间:2017-11-28 投稿人: 浏览次数:314

转载地址http://bbs.csdn.net/topics/310202381,备忘

创建测试数据

create table tb(姓名 varchar(10) , 课程 varchar(10) , 分数 int)
insert into tb values("张三" , "语文" , 74)
insert into tb values("张三" , "数学" , 83)
insert into tb values("张三" , "物理" , 93)
insert into tb values("李四" , "语文" , 74)
insert into tb values("李四" , "数学" , 84)
insert into tb values("李四" , "物理" , 94)
insert into tb values("王五" , "物理" , 94)
go

SQL SERVER 2000 静态SQL,指课程只有语文、数学、物理这三门课程。(以下同)

select 姓名 as 姓名 ,
  max(case 课程 when "语文" then 分数 else 0 end) 语文,
  max(case 课程 when "数学" then 分数 else 0 end) 数学,
  max(case 课程 when "物理" then 分数 else 0 end) 物理
from tb
group by 姓名

SQL SERVER 2000 动态SQL,指课程不止语文、数学、物理这三门课程。(以下同)

declare @sql varchar(8000)
set @sql = "select 姓名 "
select @sql = @sql + " , max(case 课程 when """ + 课程 + """ then 分数 else 0 end) [" + 课程 + "]"
from (select distinct 课程 from tb) as a
set @sql = @sql + " from tb group by 姓名"
exec(@sql) 

SQL SERVER 2005 静态SQL。

select * from (select * from tb) a pivot (max(分数) for 课程 in (语文,数学,物理)) b

SQL SERVER 2005 动态SQL。

declare @sql varchar(8000)
select @sql = isnull(@sql + "],[" , "") + 课程 from tb group by 课程
set @sql = "[" + @sql + "]"
exec ("select * from (select * from tb) a pivot (max(分数) for 课程 in (" + @sql + ")) b")
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。