首页 技术 正文
技术 2022年11月15日
0 收藏 889 点赞 2,828 浏览 1522 个字

Student表有三列,分别是姓名、课程、成绩
Name Curricula Mark
张三 语文 70
李四 数学 80
王朝 英语 59
城南 马哲 70
王朝 语文 90

我想得到的效果是,列出各个学科及格的人名:
语文 化学 数学
张三 李四
王朝

学科不止3门,可能有八门怎么弄呢?其实这就是典型的维度方向变化.

准备数据:

create table stgrade(Name varchar(10), Curricula varchar(10) , Mark int);
go
insert into stgrade values(‘张三’ , ‘语文’,’70’ );
insert into stgrade values(‘李四’ , ‘数学’,’80’);
insert into stgrade values(‘王朝’ , ‘英语’,’59’);
insert into stgrade values(‘城南’ , ‘马哲’,’70’ );
insert into stgrade values(‘王朝’ , ‘语文’,’90’ );
go

select * from stgrade;

NameCurriculaMark
张三语文70
李四数学80
王朝英语59
城南马哲70
王朝语文90

用case when 来实现根据column的值来返回同一行别的column的值,因为我们这里不需要分数,只关心Curricula 和name,所以是在分数赛选过后,进行一个case when操作.

select
case when Curricula=’语文’ then name end 语文,
case when Curricula=’数学’ then name end 数学,
case when Curricula=’英语’ then name end 英语,
case when Curricula=’马哲’ then name end 马哲
from stgrade where mark>59

语文 数学 英语 马哲
张三NULLNULLNULL
NULL李四NULLNULL
NULLNULLNULL城南
王朝NULLNULLNULL

又上面已经可以看到结果集合已经初具雏形了,要是更让每个column下的NULL消失,然后后面行的值补上来就能达到我们的要求了。

select
case when Curricula=’语文’ then name end 语文,
case when Curricula=’数学’ then name end 数学,
case when Curricula=’英语’ then name end 英语,
case when Curricula=’马哲’ then name end 马哲,
sn
from
(
select curricula,name,mark,
row_number() over(partition by curricula order by name) sn
from stgrade where mark>59
) t

语文数学英语马哲sn
NULLNULLNULL城南1
NULL李四NULLNULL1
王朝NULLNULLNULL1
张三NULLNULLNULL2

select sn,
max(case when Curricula=’语文’ then name end) 语文,
max(case when Curricula=’数学’ then name end) 数学,
max(case when Curricula=’英语’ then name end) 英语,
max(case when Curricula=’马哲’ then name end) 马哲
from
(
select curricula,name,mark,
row_number() over(partition by curricula order by name) sn
from stgrade where mark>59
) t
group by sn

sn语文数学英语马哲
1王朝李四NULL城南
2张三NULLNULLNULL

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,993
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,507
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,350
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,135
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,768
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,845