MySQL连续案例续集

01)查询学过「张三」老师授课的同学的信息

SELECT

s.*,

c.cname,

t.tname,

sc.score

FROM

t_mysql_teacher t,

t_mysql_course c,

t_mysql_student s,

t_mysql_score sc

WHERE

t.tid = c.tid

AND c.cid = sc.cid

AND sc.sid = s.sid

AND t.tname = '张三'

02)查询没有学全所有课程的同学的信息

'SELECT

s.sid,

s.sname,

count( sc.score ) n

FROM

t_mysql_student s

LEFT JOIN t_mysql_score sc ON s.sid = sc.sid

GROUP BY

s.sid,

s.sname

HAVING

n < (

SELECT

count( 1 )

FROM

t_mysql_course)

03)查询没学过"张三"老师讲授的任一门课程的学生姓名

SELECT

s.sid,

s.sname

FROM

t_mysql_score sc,

t_mysql_student s

WHERE

s.sid = sc.sid

AND sc.cid NOT IN ( SELECT cid FROM t_mysql_course c, t_mysql_teacher t WHERE c.tid = t.tid AND t.tname = '张三' )

GROUP BY

s.sid,

s.sname

复制代码
04)查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩
SELECT
s.sid,
s.sname,
avg( sc.score ) n 

FROM

t_mysql_student s,

t_mysql_score sc

WHERE

s.sid = sc.sid

AND sc.score < 60

GROUP BY

s.sid,

s.sname

复制代码
05)检索" 01 "课程分数小于 60,按分数降序排列的学生信息

SELECT

s.*,

sc.score

FROM

t_mysql_student s,

t_mysql_score sc

WHERE

s.sid = sc.sid

AND sc.cid = '01'

AND sc.score < 60

ORDER BY

sc.score DESC

06)按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩

SELECT

s.sid,

s.sname,

sum(if(sc.cid = '01',sc.score,0)) 语文,

sum(if(sc.cid = '02',sc.score,0)) 数学,

sum(if(sc.cid = '03',sc.score,0)) 英语,

ROUND(avg(sc.score),2) 平均分

FROM

t_mysql_score sc

RIGHT JOIN t_mysql_student s ON sc.sid = s.sid

GROUP BY

s.sid,

s.sname

复制代码
07)查询各科成绩最高分、最低分和平均分:

以如下形式显示:课程 ID,课程 name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率及格为>=60,中等为:70-80,优良为:80-90,优秀为:>=90

要求输出课程号和选修人数,查询结果按人数降序排列,若人数相同,按课程号升序排列

select

c.cid,

c.cname,

count(sc.sid) 人数,

max(sc.score) 最高分,

min(sc.score) 最低分,

ROUND(avg(sc.score),2) 平均分,

CONCAT(ROUND(sum(if(sc.score>=60,1,0))/(select count(1) from t_mysql_student)

*100,2),'%') 及格率,

CONCAT(ROUND(sum(if(sc.score>=70 and sc.score<80,1,0))/(select count(1) from t_mysql_student)

*100,2),'%') 中等率,

CONCAT(ROUND(sum(if(sc.score>=80 and sc.score<90,1,0))/(select count(1) from t_mysql_student)

*100,2),'%') 优良率,

CONCAT(ROUND(sum(if(sc.score>=90,1,0))/(select count(1) from t_mysql_student)

*100,2),'%') 优秀率

from

t_mysql_score sc

left join t_mysql_course c

on sc.cid = c.cid

GROUP BY

c.cid,c.cname

相关推荐
haixingtianxinghai37 分钟前
Redis的定期删除和惰性删除
数据库·redis·缓存
资深web全栈开发38 分钟前
PostgreSQL Schema 最佳实践:架构师的命名与组织艺术
数据库·postgresql
麦聪聊数据2 小时前
利用实时数据管道与 SQL2API 重构企业自动化审计架构
数据库·sql·低代码
麦聪聊数据2 小时前
重构开放生态:利用 QuickAPI 跨越遗留系统与敏捷交付的工程实践
数据库·sql·低代码·restful
百结2146 小时前
Mysql数据库操作
数据库·mysql·oracle
keep one's resolveY7 小时前
时区问题解决
数据库
Leinwin7 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
qq_417695057 小时前
机器学习与人工智能
jvm·数据库·python
漫随流水7 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
ego.iblacat7 小时前
MySQL 服务基础
数据库·mysql