当前位置:Gxlcms > 数据库问题 > SQL 行转列的两种做法

SQL 行转列的两种做法

时间:2021-07-01 10:21:17 帮助过:2人阅读

if object_id(‘tb‘)is not null drop table tb
Go
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)
go
select * from tb

-- 使用case when (SQL2000以上)
select 姓名,
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 姓名

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

SQL 行转列的两种做法

标签:

人气教程排行