MySQL多表查询综合练习答案
一、综合练习
1.1 init.sql文件内容
/*
数据导入:
Navicat Premium Data Transfer
Source Server : localhost
Source Server Type : MySQL
Source Server Version : 50624
Source Host : localhost
Source Database : sqlexam
Target Server Type : MySQL
Target Server Version : 50624
File Encoding : utf-8
Date: 10/21/2016 06:46:46 AM
*/
SET NAMES utf8;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for `class`
-- ----------------------------
DROP TABLE IF EXISTS `class`;
CREATE TABLE `class` (
`cid` int(11) NOT NULL AUTO_INCREMENT,
`caption` varchar(32) NOT NULL,
PRIMARY KEY (`cid`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `class`
-- ----------------------------
BEGIN;
INSERT INTO `class` VALUES ('1', '三年二班'), ('2', '三年三班'), ('3', '一年二班'), ('4', '二年九班');
COMMIT;
-- ----------------------------
-- Table structure for `course`
-- ----------------------------
DROP TABLE IF EXISTS `course`;
CREATE TABLE `course` (
`cid` int(11) NOT NULL AUTO_INCREMENT,
`cname` varchar(32) NOT NULL,
`teacher_id` int(11) NOT NULL,
PRIMARY KEY (`cid`),
KEY `fk_course_teacher` (`teacher_id`),
CONSTRAINT `fk_course_teacher` FOREIGN KEY (`teacher_id`) REFERENCES `teacher` (`tid`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `course`
-- ----------------------------
BEGIN;
INSERT INTO `course` VALUES ('1', '生物', '1'), ('2', '物理', '2'), ('3', '体育', '3'), ('4', '美术', '2');
COMMIT;
-- ----------------------------
-- Table structure for `score`
-- ----------------------------
DROP TABLE IF EXISTS `score`;
CREATE TABLE `score` (
`sid` int(11) NOT NULL AUTO_INCREMENT,
`student_id` int(11) NOT NULL,
`course_id` int(11) NOT NULL,
`num` int(11) NOT NULL,
PRIMARY KEY (`sid`),
KEY `fk_score_student` (`student_id`),
KEY `fk_score_course` (`course_id`),
CONSTRAINT `fk_score_course` FOREIGN KEY (`course_id`) REFERENCES `course` (`cid`),
CONSTRAINT `fk_score_student` FOREIGN KEY (`student_id`) REFERENCES `student` (`sid`)
) ENGINE=InnoDB AUTO_INCREMENT=53 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `score`
-- ----------------------------
BEGIN;
INSERT INTO `score` VALUES ('1', '1', '1', '10'), ('2', '1', '2', '9'), ('5', '1', '4', '66'), ('6', '2', '1', '8'), ('8', '2', '3', '68'), ('9', '2', '4', '99'), ('10', '3', '1', '77'), ('11', '3', '2', '66'), ('12', '3', '3', '87'), ('13', '3', '4', '99'), ('14', '4', '1', '79'), ('15', '4', '2', '11'), ('16', '4', '3', '67'), ('17', '4', '4', '100'), ('18', '5', '1', '79'), ('19', '5', '2', '11'), ('20', '5', '3', '67'), ('21', '5', '4', '100'), ('22', '6', '1', '9'), ('23', '6', '2', '100'), ('24', '6', '3', '67'), ('25', '6', '4', '100'), ('26', '7', '1', '9'), ('27', '7', '2', '100'), ('28', '7', '3', '67'), ('29', '7', '4', '88'), ('30', '8', '1', '9'), ('31', '8', '2', '100'), ('32', '8', '3', '67'), ('33', '8', '4', '88'), ('34', '9', '1', '91'), ('35', '9', '2', '88'), ('36', '9', '3', '67'), ('37', '9', '4', '22'), ('38', '10', '1', '90'), ('39', '10', '2', '77'), ('40', '10', '3', '43'), ('41', '10', '4', '87'), ('42', '11', '1', '90'), ('43', '11', '2', '77'), ('44', '11', '3', '43'), ('45', '11', '4', '87'), ('46', '12', '1', '90'), ('47', '12', '2', '77'), ('48', '12', '3', '43'), ('49', '12', '4', '87'), ('52', '13', '3', '87');
COMMIT;
-- ----------------------------
-- Table structure for `student`
-- ----------------------------
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
`sid` int(11) NOT NULL AUTO_INCREMENT,
`gender` char(1) NOT NULL,
`class_id` int(11) NOT NULL,
`sname` varchar(32) NOT NULL,
PRIMARY KEY (`sid`),
KEY `fk_class` (`class_id`),
CONSTRAINT `fk_class` FOREIGN KEY (`class_id`) REFERENCES `class` (`cid`)
) ENGINE=InnoDB AUTO_INCREMENT=17 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `student`
-- ----------------------------
BEGIN;
INSERT INTO `student` VALUES ('1', '男', '1', '理解'), ('2', '女', '1', '钢蛋'), ('3', '男', '1', '张三'), ('4', '男', '1', '张一'), ('5', '女', '1', '张二'), ('6', '男', '1', '张四'), ('7', '女', '2', '铁锤'), ('8', '男', '2', '李三'), ('9', '男', '2', '李一'), ('10', '女', '2', '李二'), ('11', '男', '2', '李四'), ('12', '女', '3', '如花'), ('13', '男', '3', '刘三'), ('14', '男', '3', '刘一'), ('15', '女', '3', '刘二'), ('16', '男', '3', '刘四');
COMMIT;
-- ----------------------------
-- Table structure for `teacher`
-- ----------------------------
DROP TABLE IF EXISTS `teacher`;
CREATE TABLE `teacher` (
`tid` int(11) NOT NULL AUTO_INCREMENT,
`tname` varchar(32) NOT NULL,
PRIMARY KEY (`tid`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `teacher`
-- ----------------------------
BEGIN;
INSERT INTO `teacher` VALUES ('1', '张磊老师'), ('2', '李平老师'), ('3', '刘海燕老师'), ('4', '朱云海老师'), ('5', '李杰老师');
COMMIT;
SET FOREIGN_KEY_CHECKS = 1;
1.2 从init.sql文件中导入数据
# 准备表、记录
mysql> create database db1;
mysql> use db1;
mysql> source /root/init.sql
1.3 基础练习
查询男生、女生的人数;
查询姓“张”的学生名单;
课程平均分从高到低显示
查询有课程成绩小于60分的同学的学号、姓名;
查询至少有一门课与学号为1的同学所学课程相同的同学的学号和姓名;
查询出只选修了一门课程的全部学生的学号和姓名;
查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;
查询课程编号“2”的成绩比课程编号“1”课程低的所有同学的学号、姓名;
查询“生物”课程比“物理”课程成绩高的所有学生的学号;
查询平均成绩大于60分的同学的学号和平均成绩;
查询所有同学的学号、姓名、选课数、总成绩;
查询姓“李”的老师的个数;
查询没学过“张磊老师”课的同学的学号、姓名;
查询学过“1”并且也学过编号“2”课程的同学的学号、姓名;
查询学过“李平老师”所教的所有课的同学的学号、姓名;
1.4 进阶练习
- 查询没有学全所有课的同学的学号、姓名;
- 查询和“002”号的同学学习的课程完全相同的其他同学学号和姓名;
- 删除学习“叶平”老师课的SC表记录;
- 向SC表中插入一些记录,这些记录要求符合以下条件:①没有上过编号“002”课程的同学学号;②插入“002”号课程的平均成绩;
- 按平均成绩从低到高显示所有学生的“语文”、“数学”、“英语”三门的课程成绩,按如下形式显示: 学生ID,语文,数学,英语,有效课程数,有效平均分;
- 查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;
- 按各科平均成绩从低到高和及格率的百分数从高到低顺序;
- 查询各科成绩前三名的记录:(不考虑成绩并列情况)
- 查询每门课程被选修的学生数;
- 查询同名同姓学生名单,并统计同名人数;
- 查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列;
- 查询平均成绩大于85的所有学生的学号. 姓名和平均成绩;
- 查询课程名称为“数学”,且分数低于60的学生姓名和分数;
- 查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;
- 求选了课程的学生人数
- 查询选修“杨艳”老师所授课程的学生中,成绩最高的学生姓名及其成绩;
- 查询各个课程及相应的选修人数;
- 查询不同课程但成绩相同的学生的学号、课程号、学生成绩;
- 查询每门课程成绩最好的前两名;
- 检索至少选修两门课程的学生学号;
- 查询全部学生都选修的课程的课程号和课程名;
- 查询没学过“叶平”老师讲授的任一门课程的学生姓名;
- 查询两门以上不及格课程的同学的学号及其平均成绩;
- 检索“004”课程分数小于60,按分数降序排列的同学学号;
- 删除“002”同学的“001”课程的成绩;
二、基础练习答案
1、查询“生物”课程比“物理”课程成绩高的所有学生的学号;
select * from(
(select * from score where course_id in (select cid from course where cname = '生物')) t1
left join
(select * from score where course_id in (select cid from course where cname = '物理')) t2
on t1.student_id = t2.student_id)
where t1.num > t2.num;
2、查询平均成绩大于60分的同学的学号和平均成绩;
# 先查看每个同学的平均分数
select student_id,avg(num) from score group by student_id;
# 在筛选成绩大于60分的同学的学号和平均成绩;
# select student_id,avg(num) from score group by student_id having avg(num) > 60;
3、查询所有同学的学号、姓名、选课数、总成绩;
# 先查看每个同学的总成绩
select student_id,sum(num) from score group by student_id;
# 学生和课程的关系只有成绩表中存在,因此要获取每个学生选择的课程,需要通过score表
select count(sid),student_id from score group by student_id;
# 将上面两步合并
select sum(num),count(sid),student_id from score group by student_id;
# 将学生的信息和成绩选课情况拼在一起
select sid,sname,sum_num ,count_stu
from student
left join
(select sum(num) sum_num,count(sid) count_stu,student_id from score group by student_id) t2
on sid = student_id;
# 还可以更严谨,那些没有选课的同学选课数和总成绩应该是0
select sid,sname,
(
CASE
WHEN sum_num is null THEN 0
ELSE sum_num
END
) as sum_num ,
(
CASE
WHEN count_stu is null THEN 0
ELSE count_stu
END
) as count_stu
from student
left join
(select sum(num) sum_num,count(sid) count_stu,student_id from score group by student_id) t2
on sid = student_id;
4、查询姓“李”的老师的个数;
# 找到所有姓李的
# 方法一
# select * from teacher where tname like '李%';
# 方法二
# select * from teacher where tname regexp '^李';
# 统计个数
select count(tid) from teacher where tname regexp '^李';
或者
select count(id) from teacher where tname like '李%';
5、查询没学过“张磊老师”课的同学的学号、姓名;
# 找到张磊老师的id
select tid from teacher where tname == '张磊老师';
# 找到张磊老师所教课程
select cid from course where teacher_id = (select tid from teacher where tname = '张磊老师');
# 找到所有学习这门课的学生id
select student_id from score where course_id = (select cid from course where teacher_id = (select tid from teacher where tname = '张磊老师'));
# 找到没有学过这门课的学生对应的学生学号、姓名
select sid,sname from student where sid not in
(select student_id from score where course_id = (select cid from course where teacher_id = (select tid from teacher where tname = '张磊老师'))
);
6、查询学过“1”并且也学过编号“2”课程的同学的学号、姓名;
# 先查询学习课程id为1的所有学生
select * from score where course_id = 1;
# 先查询学习课程id为2的所有学生
select * from score where course_id = 2;
# 把这两张表按照学生的id 内连接起来 去掉只学习某一门课程的学生
select t1.student_id from
(select student_id from score where course_id = 1) t1
inner join
(select student_id from score where course_id = 2) t2
on t1.student_id = t2.student_id
# 根据学号在学生表中找到对应的姓名
select sid,sname from student where sid in (select t1.student_id from (select student_id from score where course_id = 1) t1 inner join (select student_id from score where course_id = 2) t2 on t1.student_id = t2.student_id);
7、查询学过“李平老师”所教的所有课的同学的学号、姓名;
#找到李平老师的tid
select tid from teacher where tname ='李平老师';
# 找到李平老师教的所有课程cid
select cid from course where teacher_id in (select tid from teacher where tname ='李平老师');
# 找到李平老师教的所有课程数
select count(cid) from course where teacher_id in (select tid from teacher where tname ='李平老师');
# 找到所有学习李平老师课程的学生
select * from score where course_id in ( select cid from course where teacher_id in (select tid from teacher where tname ='李平老师'));
# 查看所有学习李平老师课程的学生选课数
select student_id,count(course_id) from score where course_id in ( select cid from course where teacher_id in (select tid from teacher where tname ='李平老师')) group by student_id;
# 找到所有选择了李平老师所有课程的学生id
select student_id from (
select student_id,count(course_id) course_count from score where course_id in ( select cid from course where teacher_id in (select tid from teacher where tname ='李平老师')) group by student_id) t1
where t1.course_count =
(select count(cid) from course where teacher_id in (select tid from teacher where tname ='李平老师'));
# 找到学生的其他信息
select sid,sname from student where sid in (
select student_id from (
select student_id,count(course_id) course_count from score where course_id in ( select cid from course where teacher_id in (select tid from teacher where tname ='李平老师')) group by student_id) t1
where t1.course_count =
(select count(cid) from course where teacher_id in (select tid from teacher where tname ='李平老师'))
);
8、查询课程编号“2”的成绩比课程编号“1”课程低的所有同学的学号、姓名;
# 先找到每个学生的课程编号“1”的和课程编号“2”的成绩组成一张表
select t1.student_id from (select num num2,student_id from score where course_id = 2) t2 inner join (select student_id,num num1 from score where course_id = 1) t1 on t1.student_id = t2.student_id
# 再找到课程编号“2”的成绩比课程编号“1”课程低的所有学生的学号
select t1.student_id from (select num num2,student_id from score where course_id = 2) t2 inner join (select student_id,num num1 from score where course_id = 1) t1 on t1.student_id = t2.student_id where num2 < num1
# 再找到所有学生的学号、姓名
select sid,sname from student where sid in(select t1.student_id from (select num num2,student_id from score where course_id = 2) t2 inner join (select student_id,num num1 from score where course_id = 1) t1 on t1.student_id = t2.student_id where num2 < num1);
9、查询有课程成绩小于60分的同学的学号、姓名;
# 先查询成绩小于60分的同学的学号
select distinct student_id from score where num < 60;
# 再查询有课程成绩小于60分的同学的学号、姓名
select sid,sname from student where sid in (select distinct student_id from score where num < 60);
10、查询至少有一门课与学号为1的同学所学课程相同的同学的学号和姓名;
# 先看看学号为1的同学都学了哪些课程
select course_id from score where student_id = 1
# 找到学习 学号为1的同学所学课程 的学号
select distinct student_id from score where course_id in (select course_id from score where student_id = 1);
# 找到学习 学号为1的同学所学课程 的学号\姓名
select sid,sname from student where sid in (select distinct student_id from score where course_id in (select course_id from score where student_id = 1));
11、课程平均分从高到低显示
select course_id,avg(num) avg_num from score group by course_id order by avg_num desc;
12、查询出只选修了一门课程的全部学生的学号和姓名;
# 查询出只选修了一门课程的全部学生的学号
select student_id,count(student_id) from score group by student_id having count(student_id) =1;
# 查询出只选修了一门课程的全部学生的学号和姓名;
select sid,sname from student where sid in (select student_id from score group by student_id having count(student_id) =1);
13、查询男生、女生的人数;
select gender,count(sid) from student group by gender;
14、查询姓“张”的学生名单;
select * from student where sname like '张%';
15、查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;
# 查询成绩的最高分
select course_id c1,max(num) from score group by course_id
# 查询成绩的最低分
select course_id c1,min(num) from score group by course_id
# 查询成绩的最高分和最低分拼接
select * from ( (select course_id c1,max(num) from score group by course_id) t1 inner join (select course_id c2,min(num) from score group by course_id) t2 on t1.c1 = t2.c2 );
# 格式整理
select t1.c1,t1.max_num,t2.min_num from ( (select course_id c1,max(num) max_num from score group by course_id) t1 inner join (select course_id c2,min(num) min_num from score group by course_id) t2 on t1.c1 = t2.c2 );
三、进阶练习答案
1、查询没有学全所有课的同学的学号、姓名;
# 先统计一共有多少门课程
select count(cid) from course;
# 查看每个学生选择的课程书
select count(course_id) from score group by student_id;
# 查询所学课程数小于总课程数的学生学号
select student_id
from (select count(course_id) c_course_id,student_id from score group by student_id) t1
where t1.c_course_id < (select count(cid) from course) ;
# 查询没有学全所有课的同学的学号、姓名;
select sid,sname from student where sid in (
select student_id from (select count(course_id) c_course_id,student_id from score group by student_id
) t1 where t1.c_course_id < (select count(cid) from course)
) ;
2、查询和“002”号的同学学习的课程完全相同的其他同学学号和姓名;
# 先查询2号同学学了哪些课程
select * from score where student_id =2;
# 找到学习了2号同学没学习课程的所有同学(找到所有和2号同学学习的课程不一样的同学)
select student_id from score where course_id not in (select course_id from score where student_id=2)
# 找到score表中所有的学生并且把 2号同学 以及(和2号同学学习的课程不一样的同学)排除出去
select student_id from score where student_id not in (select student_id from score where course_id not in (select course_id from score where student_id=2)) and student_id !=2
# 对剩余的和2号同学所选课程没有不同的同学所选课程数进行统计,如果和2号同学的课程数相同,就是选择了相同的课程
select student_id from score where student_id not in (
select student_id from score where course_id not in (select course_id from score where student_id=2)
) and student_id !=2
group by student_id
having count(course_id)= (select count(course_id) from score where student_id=2);
3、删除学习“叶平”老师课的SC(score)表记录;
# 先查出李平老师的id
select tid from teacher where tname = '李平老师';
# 查看李平老师所教授的课程
select cid from course where teacher_id = (select tid from teacher where tname = '李平老师');
# 查看李平老师所教课程的成绩数据
select * from score where course_id in (select cid from course where teacher_id = (select tid from teacher where tname = '李平老师'));
# 执行删除命令
delete from score where course_id in (select cid from course where teacher_id = (select tid from teacher where tname = '李平老师'));
4、向SC表中插入一些记录,这些记录要求符合以下条件:①没有上过编号“002”课程的同学学号;②插入“002”号课程的平均成绩;
# 先找寻上过2号课程的同学
select student_id from score where course_id = 2;
# 再找到没上过2号课程的所有同学
select * from student where sid not in (select student_id from score where course_id = 2);
# 计算出学习2号课程的同学的平均成绩
select avg(num) from score where course_id = 2 group by course_id;
# 用笛卡尔积将上述两个表拼起来
select * from (select sid from student where sid not in (select student_id from score where course_id = 2)) t1,(select avg(num) from score where course_id = 2 group by course_id) t2;
# 向SC表中插入记录
insert into score (course_id,student_id,num) select 2,t1.sid,t2.avg_num from (select sid from student where sid not in (select student_id from score where course_id = 2)) t1,(select avg(num) avg_num from score where course_id = 2 group by course_id) t2;
5、按平均成绩从低到高显示所有学生的“语文”、“数学”、“英语”三门的课程成绩,按如下形式显示: 学生ID,语文,数学,英语,有效课程数,有效平均分;
# 查看每个学生的数学成绩
select student_id,num from score where course_id = (select cid from course where cname = '数学');
# 查看每个学生的语文成绩
select student_id,num from score where course_id = (select cid from course where cname = '语文');
# 查看每个学生的英语成绩
select student_id,num from score where course_id = (select cid from course where cname = '英语');
# 查看每个学生的平均成绩
select student_id,avg(num),count(num) from score group by student_id;
# 将上面的几张表拼接起来,为了生成所有学生的信息,用student表作为左连接的第一张表
select sid 学生ID,t2.num 语文,t1.num 数学, t3.num 英语,t4.count_course 有效课程数,t4.avg_num 有效平均分 from student
left join (select student_id,num from score where course_id = (select cid from course where cname = '数学')) t1
on student.sid = t1.student_id
left join (select student_id,num from score where course_id = (select cid from course where cname = '语文')) t2
on student.sid = t2.student_id
left join (select student_id,num from score where course_id = (select cid from course where cname = '英语')) t3
on student.sid = t3.student_id
left join (select student_id,avg(num) avg_num,count(num) count_course from score group by student_id) t4
on student.sid = t4.student_id
6、查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;
select course_id 课程ID,max(num) 最高分,min(num) 最低分 from score group by course_id;
7、按各科平均成绩从低到高和及格率的百分数从高到低顺序;
# 方法1:
# 先求平均成绩
select course_id,avg(num) from score group by course_id;
# 解决计算各科及格率的问题
所有及格的人/所有人数
select t1.course_id,t1.count1/t2.count2 from
(select course_id,count(course_id) count1 from score where num>60 group by course_id) t1
left join
(select course_id,count(course_id) count2 from score group by course_id) t2
on t1.course_id = t2.course_id;
# 根据上述内容进行表的拼接
select t_out1.course_id,t_out1.avgnum, t_out2.pass_per from
(select course_id,avg(num) avgnum from score group by course_id ) t_out1
left join
(select t1.course_id,t1.count1/t2.count2 pass_per from
(select course_id,count(course_id) count1 from score where num>60 group by course_id) t1
left join
(select course_id,count(course_id) count2 from score group by course_id) t2
on t1.course_id = t2.course_id) t_out2
on t_out1.course_id = t_out2.course_id
# 加上排序
select t_out1.course_id,t_out1.avgnum, t_out2.pass_per from (select course_id,avg(num) avgnum from score group by course_id ) t_out1 left join (select t1.course_id,t1.count1/t2.count2 pass_per from (select course_id,count(course_id) count1 from score where num>60 group by course_id) t1 left join (select course_id,count(course_id) count2 from score group by course_id) t2 on t1.course_id = t2.course_id) t_out2 on t_out1.course_id = t_out2.course_id order by avgnum ,pass_per desc;
# 方法2
# 使用case when直接计算合格率
select
sum(case when num>60 then 1 else 0 end)/count(course_id)
from score group by course_id
# 加上课程id和平均值
select course_id,avg(num),
sum(case when num>60 then 1 else 0 end)/count(course_id)
from score group by course_id
# 加上排序
select course_id,avg(num) avgnum,
sum(case when num>60 then 1 else 0 end)/count(course_id) pass_per
from score group by course_id
order by avgnum ,pass_per desc;
8、查询各科成绩前三名的记录:(不考虑成绩并列情况)
select
t1.sid,t1.student_id,t1.course_id,t1.num from score t1
left join
(
select sid,course_id,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 0, 1) as first_num,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 1, 1) as second_num,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 2, 1) as third_num
from score as s1
) t2
on t1.sid = t2.sid
where t1.num = t2.first_num or t1.num = t2.second_num or t1.num = t2.third_num;
9、查询每门课程被选修的学生数;
select course_id,count(course_id) from score group by course_id;
10、查询同名同姓学生名单,并统计同名人数;
select sname,count(1) as count from student group by sname;
11、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列;
select course_id,avg(if(isnull(num), 0 ,num)) as avg from score group by course_id order by avg asc,course_id desc;
12、查询平均成绩大于85的所有学生的学号、姓名和平均成绩;
select student_id,sname, avg(if(isnull(num), 0 ,num)) from score left join student on score.student_id = student.sid group by student_id;
13、查询课程名称为“数学”,且分数低于60的学生姓名和分数;
select student.sname,score.num from score
left join course on score.course_id = course.cid
left join student on score.student_id = student.sid
where score.num < 60 and course.cname = '数学'
14、查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;
select * from score where score.student_id = 3 and score.num > 80
15、求选了课程的学生人数
select sid,sname from student where sid not in (select student_id from score group by student_id);
16、查询选修“杨艳”老师所授课程的学生中,成绩最高的学生姓名及其成绩;
# 先找到“杨艳”老师的教师id
select tid from teacher where tname = '杨艳';
# 再找到杨艳老师教的所有课程
select cid from course where teacher_id in (select tid from teacher where tname = '杨艳');
# 再找到杨艳老师教的所有课程的最高分
select max(num) from score where course_id in (select cid from course where teacher_id in (select tid from teacher where tname = '李平老师'));
# 再找到杨艳老师教的所有课程的最高分对应的学生
select distinct student_id,num from score
where num = (select max(num) from score where course_id in (select cid from course where teacher_id in (select tid from teacher where tname = '李平老师')))
and course_id in (select cid from course where teacher_id in (select tid from teacher where tname = '李平老师'));
# 找到学生的姓名
select student.sname,t1.num from(
select distinct student_id,num from score
where num = (select max(num) from score where course_id in (select cid from course where teacher_id in (select tid from teacher where tname = '李平老师')))
and course_id in (select cid from course where teacher_id in (select tid from teacher where tname = '李平老师'))
) t1
left join
student
on
t1.student_id = student.sid;
17、查询各个课程及相应的选修人数;
select course.cname,count(1) from score
left join course on score.course_id = course.cid
group by course_id;
18、查询不同课程但成绩相同的学生的学号、课程号、学生成绩;
select DISTINCT s1.course_id,s2.course_id,s1.num,s2.num from score as s1, score as s2 where s1.num = s2.num and s1.course_id != s2.course_id;
19、查询每门课程成绩最好的前两名;
先查询每条数据对应学科成绩的第一名和第二名,这里必须要保留所有的s1,以便后续进行连表查询
select sid,course_id,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 0, 1) as first_num,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 1, 1) as second_num
from score as s1
按照sid连表,把学生的成绩和对应的第一名、第二名成绩连起来
select
* from score t1
left join
(
select sid,course_id,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 0, 1) as first_num,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 1, 1) as second_num
from score as s1
) t2
on t1.sid = t2.sid
判断如果学生的成绩是第一名、第二名的成绩,那么就符合条件,显示学生的id、学科和成绩
select
t1.sid,t1.student_id,t1.course_id,t1.num from score t1
left join
(
select sid,course_id,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 0, 1) as first_num,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 1, 1) as second_num
from score as s1
) t2
on t1.sid = t2.sid
where t1.num = t2.first_num or t1.num = t2.second_num;
20、检索至少选修两门课程的学生学号;
select student_id from score group by student_id having count(student_id) > 1;
21、查询全部学生都选修的课程的课程号和课程名;
# 先查看一共有多少学生
select count(sid) from student;
# 查看哪一门课选秀的学生个数和学生的总个数相等
select course_id from score group by course_id having count(student_id) = (select count(sid) from student);
22、查询没学过“叶平”老师讲授的任一门课程的学生姓名;
# 先查看要查找老师的id
select tid from teacher where tname = '李平老师';
# 查看该老师交了哪些课程
select cid from course where teacher_id in (select tid from teacher where tname = '李平老师')
# 看看有多少学生学习了该老师的课程
select distinct student_id from score where course_id in (select cid from course where teacher_id in (select tid from teacher where tname = '李平老师'));
# 把不在上表中的学生姓名查出来
select sname from student where sid not in (select distinct student_id from score where course_id in (select cid from course where teacher_id in (select tid from teacher where tname = '李平老师')));
23、查询两门以上不及格课程的同学的学号及其平均成绩;
select student_id,avg(num) from score where num<60 group by student_id having count(num)>=2;
24、检索“004”课程分数小于60,按分数降序排列的同学学号;
select student_id from score where num< 60 and course_id = 4 order by num desc;
25、删除“002”同学的“001”课程的成绩;
delete from score where course_id = 1 and student_id = 2;
MySQL多表查询综合练习答案的更多相关文章
- python3 mysql 多表查询
python3 mysql 多表查询 一.准备表 创建二张表: company.employee company.department #建表 create table department( id ...
- MySQL多表查询之外键、表连接、子查询、索引
MySQL多表查询之外键.表连接.子查询.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为 ...
- Mysql 单表查询 子查询 关联查询
数据准备: ## 学院表create table department( d_id int primary key auto_increment, d_name varchar(20) not nul ...
- (转)Mysql 多表查询详解
MySQL 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到mysql中关键字执行的顺序,只涉及了一张表:实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有 ...
- MySQL多表查询回顾
----------------------siwuxie095 MySQL 多表查询回顾 以客户和联系人为例(一对多) 1.内连接 /*内连接写法一*/ select * from t_custom ...
- python 3 mysql 单表查询
python 3 mysql 单表查询 1.准备表 company.employee 员工id id int 姓名 emp_name varchar 性别 sex enum 年龄 age int 入职 ...
- Mysql 单表查询-排序-分页-group by初识
Mysql 单表查询-排序-分页-group by初识 对于select 来说, 分组聚合(((group by; aggregation), 排序 (order by** ), 分页查询 (limi ...
- Mysql 单表查询where初识
Mysql 单表查询where初识 准备数据 -- 创建测试库 -- drop database if exists student_db; create database student_db ch ...
- MySQL多表查询合并结果union all,内连接查询
MySQL多表查询合并结果和内连接查询 1.使用union和union all合并两个查询结果:select 字段名 from tablename1 union select 字段名 from tab ...
随机推荐
- 【实习第十天】odoo开发基础整合
前言 发文时间是2019年7月19日.提一下学习odoo的感受,odoo目前在国内并不是很流行,且主流是在企业型软件,所以导致目前odoo在网上的文献很少,学习相对来说比其他框架吃力.以下为大家总结1 ...
- (草稿)如何判断一名UiPath开发人员是否合格?
一名合格的UiPath开发人员究竟需要具备什么核心技能?业务梳理?沟通技巧?VB.net吗?VBA吗?Python?还是SQL?出于多种原因,关于这一点总是众说纷纭,莫衷一是.尽管这些技术都算沾边,但 ...
- 卡拉OK歌词原理和实现高仿Android网易云音乐
大家好,我们是爱学啊,继上一篇讲解了[LRC歌词原理和实现高仿Android网易云音乐],今天给大家带来一篇关于卡拉OK歌词原理和在Android上如何实现歌词逐字滚动的效果,本文来自[Android ...
- AndroidStudio集成.so遇见的问题:关于java.lang.UnsatisfiedLinkError: Native method not found
我调试的是串口程序,程序中需要继承.so文件,AndroidStudio中集成.so文件的方法是将存放.so的文件夹(通常这个文件夹名字是:armeabi)拷贝到app的libs文件夹中,然后在app ...
- Linux发行版的系统目录名称命名规则以及用途
linux各种发行版都遵循LSB(Linux Stadards Base)规则,使用一致的相关的基础目录名称,使用根目录系统结构(root filesystem),使用FHS(Files Hierar ...
- 不能绑定到端口号:9194原因:Cannot assign requested address: JVM_Bind
晚上将老服务器程序从win2008部署在新的云服务器win2012上,其实就是复制过去改改配置,启动时突然报不能绑定到端口号:9194原因:Cannot assign requested addres ...
- Python语法速查:目录
1. 数据类型与内置函数 2. 列表.元组.字典.集合操作 3. 字符串格式化 4. 字符串常用操作 5. 运算符.math模块.表达式 6. 循环与迭代 7. 函数基础 8. 类与对象 9. 函数进 ...
- "echo 0 /proc/sys/kernel/hung_task_timeout_secs" disable this message
问题现象: 问题原因: 默认情况下, Linux会最多使用40%的可用内存作为文件系统缓存.当超过这个阈值后,文件系统会把将缓存中的内存全部写入磁盘, 导致后续的IO请求都是同步的. 将缓存写入磁盘时 ...
- 简单搭建docker registry
已知信息: 服务端IP:192.168.7.2xx 客户端IP:192.168.7.1xx 服务端: docker registry中镜像本地映射地址:/Users/dockergit/private ...
- IT兄弟连 HTML5教程 CSS3揭秘 CSS3属性1
通过CSS选择器找到元素,就要使用CSS属性给找到的元素设置样式.尽管现在的浏览器已经支持了众多的CSS3属性,但作为初学者,最应该关注的就是一些“主流”的属性,如border-radius.box- ...