mysql中嵌套查询分数大于70分的人数_MySQL查询练习题,自我解答版本
#1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数
SELECT c.*,a.s_score,b.s_score
FROM score AS a,score AS b,student AS c
WHERE c.s_id=a.s_id AND a.s_id=b.s_id AND a.c_id='01'AND b.c_id='02'AND a.s_score>b.s_score;
#2、查询"01"课程比"02"课程成绩低的学生的信息及课程分数
SELECT c.*,a.s_score,b.s_score
FROM score AS a,score AS b,student AS c
WHERE c.s_id=a.s_id AND a.s_id=b.s_id AND a.c_id='01'AND b.c_id='02'AND a.s_score
#3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩
SELECT a.*,AVG(b.s_score)AS total
FROM student AS a,score AS b
WHERE a.s_id=b.s_id
GROUP BY a.s_id
HAVING total>=60;
#4、查询平均成绩小于60分的同学的学生编号和学生姓名和平均成绩
SELECT a.*,AVG(IFNULL(b.s_score,0))AS total
FROM student AS a
LEFT JOIN score AS b ON a.s_id=b.s_id
GROUP BY a.s_id
HAVING total<60;
#5、查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩
SELECT a.s_id,a.s_name,COUNT(b.c_id),SUM(IFNULL(b.s_score,0))
FROM student AS a
LEFT JOIN score AS b ON a.s_id=b.s_id
GROUP BY a.s_id;
#6、查询"李"姓老师的数量
SELECT COUNT(1)
FROM teacher AS a
WHERE a.t_name LIKE'李%';
#7、查询学过"张三"老师授课的同学的信息
SELECT a.*
FROM student AS a WHERE a.s_idIN(
SELECT s.s_id FROM score AS s WHERE s.c_id=(
(SELECT c.c_idFROM course AS c WHERE c.t_id=(
SELECT t.t_id FROM teacher AS t WHERE t.t_name='张三'))));
#8、查询没学过"张三"老师授课的同学的信息
SELECT a.*
FROM student AS a WHERE a.s_id NOT IN(
SELECT s.s_id FROM score AS s WHERE s.c_id=(
(SELECT c.c_idFROM course AS c WHERE c.t_id=(
SELECT t.t_id FROM teacher AS t WHERE t.t_name='张三'))));
#9、查询学过编号为"01"并且也学过编号为"02"的课程的同学的信息
SELECT a.*
FROM student AS a
WHERE a.s_idIN(SELECT b.s_id FROM score AS b WHERE b.c_id='01')
AND a.s_idIN(SELECT c.s_id FROM score AS c WHERE c.c_id='02');
#10、查询学过编号为"01"但是没有学过编号为"02"的课程的同学的信息
SELECT a.*
FROM student AS a
WHERE a.s_idIN(SELECT b.s_id FROM score AS b WHERE b.c_id='01')
AND a.s_id NOT IN(SELECT c.s_id FROM score AS c WHERE c.c_id='02');
#11、查询没有学全所有课程的同学的信息
SELECT a.*
FROM student AS a
LEFT JOIN score AS b ON a.s_id=b.s_id
GROUP BY a.s_id
HAVING COUNT(1)
#12、查询至少有一门课与学号为"01"的同学所学相同的同学的信息
SELECT DISTINCT a.*
FROM student AS a
LEFT JOIN score AS b ON a.s_id=b.s_id
WHERE b.c_id IN
(SELECT c.c_idFROM score AS c WHERE c.s_id='01')
AND b.s_id!='01';
#13、查询和"01"号的同学学习的课程完全相同的其他同学的信息
SELECT a.*
FROM student AS a
WHERE a.s_id!='01' AND a.s_id IN
(SELECT b.s_idFROM score AS b GROUP BY b.s_id HAVING COUNT(1)=(SELECT COUNT(1)FROM score WHERE score.s_id='01'));
#15、查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩
SELECT a.s_id,a.s_name, AVG(IFNULL(b.s_score,0))
FROM student AS a
LEFT JOIN score AS b ON a.s_id=b.s_id
WHERE IFNULL(b.s_score,0)<60
GROUP BY a.s_id
HAVING COUNT(1)>=2
#16、检索"01"课程分数小于60,按分数降序排列的学生信息
SELECT a.*
FROM student AS a
LEFT JOIN score AS b ON a.s_id=b.s_id
WHERE b.c_id='01'AND b.s_score<60;
#17、按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩
SELECT a.*,(SELECT score.s_scoreFROM score WHERE a.s_id=score.s_id AND score.c_id='01')AS 语文,
(SELECT score.s_scoreFROM score WHERE a.s_id=score.s_id AND score.c_id='02')AS 数学,
(SELECT score.s_scoreFROM score WHERE a.s_id=score.s_id AND score.c_id='03')AS 英语,
ROUND(AVG(b.s_score),2)AS 平均成绩
FROM student AS a INNER JOIN score AS b ON a.s_id=b.s_id GROUP BY a.s_id ORDER BY 平均成绩 DESC;
#18.查询各科成绩最高分、最低分和平均分:以如下形式显示:课程ID,课程name,最高分,
#最低分,平均分,及格率,中等率,优良率,优秀率
#--及格为>=60,中等为:70-80,优良为:80-90,优秀为:>=90
SELECT b.c_id,b.c_name,MAX(a.s_score),MIN(a.s_score),AVG(a.s_score)
,(SUM(CASE WHEN a.s_score>=90 THEN 1 ELSE 0 END)/COUNT(1)) AS 优秀率
,(SUM(CASE WHEN a.s_score>=80 AND a.s_score<90 THEN 1 ELSE 0 END)/COUNT(1)) AS 优良率
,(SUM(CASE WHEN a.s_score>=70 AND a.s_score<80 THEN 1 ELSE 0 END)/COUNT(1)) AS 中等率
,(SUM(CASE WHEN a.s_score>=60 THEN 1 ELSE 0 END)/COUNT(1)) AS 及格率
FROM score AS a,course AS b WHERE a.c_id=b.c_id
GROUP BY a.c_id;
#21、查询不同老师所教不同课程平均分从高到低显示
SELECT b.t_id,b.c_name,AVG(a.s_score)AS avg
FROM score AS a,course AS b WHERE b.c_id=a.c_id
GROUP BY b.c_id
ORDER BY avgDESC;
#23、统计各科成绩各分数段人数:课程编号,课程名称,[100-85],[85-70],[70-60],[0-60]及所占百分比
SELECT b.c_id,b.c_name
,(SUM(CASE WHEN a.s_score>=85 THEN 1 ELSE 0 END)/COUNT(1))AS '[100-85]'
,(SUM(CASE WHEN a.s_score>=70 AND a.s_score<85 THEN 1 ELSE 0 END)/COUNT(1))AS '[85-70]'
,(SUM(CASE WHEN a.s_score>=60 AND a.s_score<70 THEN 1 ELSE 0 END)/COUNT(1))AS '[70-60]'
,(SUM(CASE WHEN a.s_score<60 THEN 1 ELSE 0 END)/COUNT(1))AS '[0-60]'
FROM score AS a ,course AS b WHERE b.c_id=a.c_id
GROUP BY b.c_id;
#26查询每门课程被选修的学生数
SELECT score.c_id,COUNT(1) FROM score GROUP BY score.c_id;
#27查询出只有两门课程的全部学生的学号和姓名
SELECT a.*
FROM student AS a,score AS b
WHERE a.s_id=b.s_id
GROUP BY a.s_id
HAVING COUNT(1)=2;
#28查询男生、女生人数
SELECT a.s_sex,COUNT(1) FROM student AS a GROUP BY a.s_sex;
#29查询名字中含有"风"字的学生信息
SELECT a.* FROM student AS a WHERE a.s_name LIKE '%风%';
#30、查询同名同性学生名单,并统计同名人数
SELECT a.s_name,COUNT(1)
FROM student AS a,student AS b
WHERE a.s_name=b.s_name AND a.s_id!=b.s_id
GROUP BY a.s_name;
#31、查询1990年出生的学生名单
SELECT a.*FROM student AS a WHERE YEAR(a.s_birth)='1990';
#32、查询每门课程的平均成绩,结果按平均成绩降序排列,平均成绩相同时,按课程编号升序排列
SELECT a.c_id,AVG(a.s_score)AS avg FROM score AS a GROUP BY a.c_id ORDER BY avgDESC;
#33、查询平均成绩大于等于85的所有学生的学号、姓名和平均成绩
SELECT a.*,AVG(b.s_score)AS avg
FROM student AS a,score AS b
WHERE a.s_id=b.s_id
GROUP BY a.s_id
HAVING avg>=85;
#34、查询课程名称为"数学",且分数低于60的学生姓名和分数
SELECT b.s_name,c.s_score FROM student AS b ,score AS c WHERE b.s_id=c.s_id AND c.c_id=
(SELECT a.c_id FROM course AS a WHERE a.c_name='数学') AND c.s_score<60;
#35、查询所有学生的课程及分数情况
SELECT a.*,(SELECT b.s_score FROM score AS b WHERE b.c_id='01' AND a.s_id=b.s_id)AS chinese
,(SELECT b.s_score FROM score AS b WHERE b.c_id='02' AND a.s_id=b.s_id)AS math
,(SELECT b.s_score FROM score AS b WHERE b.c_id='03' AND a.s_id=b.s_id)AS english
FROM student AS a;
#36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数;
SELECT a.s_name,c.c_name,b.s_score
FROM student a,score b,course c
WHERE a.s_id=b.s_id AND b.c_id=c.c_idAND b.s_score>70;
#37、查询不及格的课程
SELECT a.s_id,a.c_id,b.c_name,a.s_score
FROM score AS a,course AS b
WHERE a.c_id=b.c_id AND a.s_score<60;
#38、查询课程编号为01且课程成绩在70分以上的学生的学号和姓名;
SELECT a.s_id,a.s_name,b.s_score
FROM student AS a,score AS b
WHERE a.s_id=b.s_id AND b.c_id='01'AND b.s_score>70;
#39、求每门课程的学生人数
SELECT COUNT(1) FROM score AS a GROUP BY a.c_id;
#40、查询选修"张三"老师所授课程的学生中,成绩最高的学生信息及其成绩
SELECT a.*,b.c_id,b.s_score FROM student AS a ,score AS b WHERE a.s_id=b.s_id AND b.c_id=
(SELECT c.c_id FROM course AS c WHERE c.t_id=
(SELECT t.t_id FROM teacher AS t WHERE t.t_name='张三'))
ORDER BY b.s_scoreDESC;
#41、查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩
SELECT DISTINCT a.s_id,b.c_id,b.s_score
FROM student AS a,score AS b,score AS c
WHERE a.s_id=b.s_id AND b.c_id!=c.c_id AND b.s_score=c.s_score;
#43、统计每门课程的学生选修人数(超过5人的课程才统计)。要求输出课程号和选修人数,
#查询结果按人数降序排列,若人数相同,按课程号升序排列
SELECT a.c_id,COUNT(1)AS 人数
FROM score AS a
GROUP BY a.c_id
HAVING 人数>5
ORDER BY 人数 DESC ,a.c_id ASC;
#44、检索至少选修两门课程的学生学号
SELECT a.s_id,COUNT(1)AS 选课数
FROM score AS a
GROUP BY a.s_id
HAVING 选课数>=2;
#45、查询选修了全部课程的学生信息
SELECT a.* FROM student AS a,score AS b
WHERE a.s_id=b.s_id
GROUP BY a.s_id
HAVING COUNT(1)=(SELECT COUNT(1)FROM course );
#46、查询各学生的年龄
SELECT a.*,(YEAR(NOW())-YEAR(a.s_birth))AS 年龄
FROM student AS a ;
#47、查询本周过生日的学生
SELECT *FROM student WHERE (WEEK(NOW())-WEEK(student.s_birth))=0;
#48查询下周过生日的学生
SELECT * FROM student WHERE (WEEK(student.s_birth)-WEEK(NOW()))=1;
#49、查询本月过生日的学生
SELECT * FROM student WHERE MONTH(NOW())=MONTH(student.s_birth);
#50、查询下月过生日的学生
SELECT * FROM student WHERE MONTH(NOW())+1=MONTH(student.s_birth);
mysql中嵌套查询分数大于70分的人数_MySQL查询练习题,自我解答版本相关推荐
- mysql查询选修课的人数_mysql查询语句练习
#建学生信息表student create table student ( sno varchar(20) not null primary key, sname varchar(20) not nu ...
- mysql查询sex为男的记录总数_mysql 查询 45 道题
一. 设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...
- 请查询某一科目分数大于85分的所有学生的名单
这是一道面试题 题目照片-- CREATE DATABASE interview; USE interview; --学生表字段分别表示:学生ID,学生所属班级ID,学生名称 CREATE TABLE ...
- MySQL中嵌套子查询删除出错解决方案
MySQL中嵌套子查询做删除操作会出错,例如下面的SQL: delete from table1 where number in (select number from table2) 执行提示: Y ...
- 周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,表中没有的课程列值为空的解决方法
周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号.课程名称.选修人数,表中没有的课程列值为空的解决方法 实验前期准备 course表(课程表) 在其中: c ...
- Excel学习笔记(一):python读写excel,并完成计算平均成绩、成绩等级划分、每个同学分数大于70的次数、找最优成绩
文章目录 环境和所需准备 代码解读 整体代码 运行结果 环境和所需准备 执行这个程序需要安装以下python环境 pip install openpyxl -i https://pypi.tuna.t ...
- mysql查询成绩大于89分_查询每门课程成绩都大于80分学生的姓名
转载的sql语句 .1 查询每门课程成绩都大于80分学生的学号 数据库 表 student name score course A 85 语文 A 75 数学 A 82 英语 B 75 语 ...
- 洪君:查出“张”姓学生中平均成绩大于75分的学生信息查询出每门课程的成绩都大于80的学生
查询出"张"姓学生中平均成绩大于75分的学生信息 表名:student_score name course score 张青 语文 72 王华 数学 72 张华 英语 81 ...
- Mysql中嵌套查询和连接查询的区别
一.嵌套查询 嵌套查询我们以mybatis中的嵌套查询举例: 1.1.创建数据库 CREATE TABLE `teacher` (`id` INT(10) NOT NULL,`name` VARCHA ...
最新文章
- CSDN 数学公式居中
- AlphaFold2爆火背后,人类为什么要死磕蛋白质?
- 马斯克脑机接口遭质疑:不是新技术,没体现神经解码进展
- 【数据结构-排序】4.图解归并排序和基数排序
- html日期横向拖动选择控件,一个简单横向javascript日期控件
- python 抢购口罩_Python 京东口罩监控+抢购
- leetcode No.123 买卖股票的最佳时机 III
- npm install -s -d -g之间的区别
- QQ截图“钉在桌面上”:不用另外下载软件让图片在屏幕置顶,永远保持在最前面、最顶端
- Wincc常用C脚本
- Macbook Pro 外接显示器关闭內建屏幕的方法,开盖状态
- 请问一下Android Studio如何配置JAVACV 0.8Javacv+2.4.9Opencv 万分感谢
- 百度地图API调用问题-sn 的生成
- IT产品是计算机类产品吗,IT产品是什么
- BZOJ2215 : [Poi2011]Conspiracy
- 不小心删库了,试试binlog
- 30个新职业薪酬出炉,程序员霸屏
- wp/wordpress文章页面添加阅读量/点击量,后台并显示阅读量
- php页面分页6,关于 ThinkPHP6 分页样式的定制及点击下一页搜索条件丢失的解决方法...
- PL/SQL Developer出现中文乱码----AMERICAN_AMERICA.ZHS16GBK
热门文章
- 24位RGB转16位RGB原理
- Java while循环与dowhile循环
- 新浪微博的方向,Twitte的IPO
- c语言float转bcd码
- 如何开始自动化员工招聘的五个提示
- Boki: Stateful Serverless Computing with Shared Logs 笔记
- 财务系统软件c语言,用vc++6.0编写一个简单的财务应用程序来计算职工所得的实际工资...
- k8s之滚动更新及pod流量分析
- 双屏Android NDS模拟器,Android DraStic(NDS模拟器)r2.5.2.1a 内购版+金手指
- 有关最近中国大学排行榜的讨论