一道面试题引发的数据库SQL语句实践(含行列转换)

本文介绍了如何通过SQL查询找出数据库中每门课程成绩都大于等于80分的学生,提供了三种不同的解决方案,包括行列转换、group by与聚合函数的结合使用,以及排除有任一课程低于80分的学生。讨论了不同方案的执行效率和适用场景,并给出了实际的数据库脚本和查询结果截图。
摘要由CSDN通过智能技术生成

问题场景

最近有个朋友去面试,问了我一道面试题。题目如下,在形如下面的数据库表score中,找出每门成绩(grade)都大于等于80分的学生姓名。

----------------------------------------
name      | course  | grade
----------------------------------------
zhangsan  | Java   | 70
----------------------------------------
zhangsan  | C++    | 80
----------------------------------------
lisi     | Java   | 90
----------------------------------------
lisi     | C++    | 60
----------------------------------------
wangwu   | Java   | 85
----------------------------------------
wangwu   | C++   | 95
----------------------------------------
 
期望结果
----------------------------------------
name
----------------------------------------
wangwu
----------------------------------------
 
本文以MySQL数据库为例,以三种方案一步一步实现面试题要求。
 
方案一
1、寻求行列转换,也称矩阵转置,将多列数据转为一行,这一步最关键,实现SQL语句如下:
下面的sql是以score为主表来构建多列,构造的从表为每门课程的数据表,通过主表的 name 字段来关联从表的 name 字段。
select s.`name` as name,
(select grade from score where name = s.`name` and course = 'Java')as 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值