按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显示: 学生ID,,数据库,企业管理,英语,有效课程数,有效平均分


MySQL的写法:

SELECT p.学生ID,p.数据库,p.企业管理,p.英语,p.有效课程数,ROUND(p.总分/(CASE WHEN p.有效课程数 = 0 THEN 1 ELSE p.有效课程数 END)) 有效平均分 FROM (SELECT t.学生ID 学生ID,     t.数据库 数据库,   t.企业管理 企业管理, t.英语 英语, (CASE WHEN t.数据库 IS NULL THEN 0 ELSE 1 END)+(CASE WHEN t.企业管理 IS NULL THEN 0 ELSE 1 END)+(CASE WHEN t.英语 IS NULL THEN 0 ELSE 1 END) 有效课程数, IFNULL(t.数据库,0)+IFNULL(t.企业管理,0)+IFNULL(t.英语,0) 总分 FROM (SELECT stu.sid 学生ID, s.c 数据库,q.c 企业管理,y.c 英语 FROM student stu LEFT JOIN (SELECT sc.sid n,sc.score c FROM sc ,course c WHERE sc.cid=c.cid AND c.cName ='数据库') s ON stu.sid=s.n LEFT JOIN (SELECT sc.sid n,sc.score c FROM sc ,course c WHERE sc.cid=c.cid AND c.cName ='企业管理') q ON stu.sid=q.n LEFT JOIN (SELECT sc.sid n,sc.score c FROM sc ,course c WHERE sc.cid=c.cid AND c.cName ='英语') Y ON stu.sid=y.n )t )p ORDER BY 有效平均分 DESC;

MySQL判断为null,写法为is null,而不是  t.数据库 = NULL 

IFNULL(expr1,expr2)

如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2。IFNULL()返回一个数字或字符串值


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



猜您在找 按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显示: 学生ID,,数据库,企业管理,英语,有效课程数,有效平均分 【sql:练习题】按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩 学生成绩表数据包括:学号,姓名,高数,英语和计算机三门课成绩,计算每个学生总分,每课程平均分,最高分和最低分 练习9--检索"01"课程分数小于60,按分数降序排列的学生信息 | 按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩 Oracle数据库作业-6 查询成绩比该课程平均成绩低的同学的成绩表 【C语言】利用文本编辑软件在磁盘上建立一个有n个学生的学号、姓名及英语、数学和计算机三门课程成绩的数据文件。编写程序将数据文件读入,且求出每个学生的平均成绩。 有10个学生,每个学生的数据包括学号、姓名、3门课程的成绩,从键盘输人10个学生数据,要求输出3门课程总平均成绩,以及最高分的学生的数据(包括学号、姓名、3门课程成绩、平均分数) 有10个学生,每个学生的数据包括学号、姓名、3门课程的成绩,从键盘输人10个学生数据,要求输出3门课程总平均成绩,以及最高分的学生的数据(包括学号、姓名、3门课程成绩、平均分数) 数据库-查询“001”课程比“002”课程成绩高的所有学生的学号 /* * 有五个学生,每个学生有3门课的成绩,从键盘输入以上数据 *(包括学生号,姓名,三门课成绩),计算出平均成绩, *将原有的数据和计算出的平均分数存放在磁盘文件"stud"中。 */
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM