多表查询

笛卡尔积

将两表所有的数据一一对应,生成一张大表 不建议

select * from dep,emp;  #两个表拼一起
select * from dep,emp where dep.id = emp.dep_id; #找到两表之间对应的关系记录
select * from dep,emp where dep.id = emp.dep_id and dep.name='技术'; #筛选部门名称为技术的大表中的记录
select emp.name from dep,emp where dep.id = emp.dep_id and dep.name='技术'; #拿到筛选后的记录的员工姓名字段数据

连表查询

inner join 内连接

select * from 表名 inner join 表9 on dep.id=emp.dep_id;
第一步:连表
	select * from dep inner join emp on dep.id=emp.dep_id;
第二步: 过滤
	select * from dep inner join emp on dep.id=emp.dep_id where dep.name='技术';
第三步:找对应字段数据
	select emp.name from dep inner join emp on dep.id=emp.dep_id where dep.name='技术';

left join 左连接(left join左边的表为主表,主表记录必须全部显示,辅表没办法对应上的,就通过null来补全)

select * from dep left join emp on dep.id=emp.dep_id;

right join 右连接

select * from dep right join emp on dep.id=emp.dep_id;

union 全连接

mysql> select * from dep left join emp on dep.id=emp.dep_id
    -> union
    -> select * from dep right join emp on dep.id=emp.dep_id;

子查询

(一个查询结果集作为另一个查询的条件)

select name from emp where dep_id = (select id from dep where name = '技术');

小练习1

书名	作者	出版社	价格	出版日期
倚天屠龙记	egon	北京工业地雷出版社 	70	2019-7-1
九阳神功	alex	人民音乐不好听出版社	5	2018-7-4
九阴真经 	yuan	北京工业地雷出版社	62	2017-7-12
九阴白骨爪	jinxin	人民音乐不好听出版社	40	2019–8-7
独孤九剑	alex	北京工业地雷出版社 	12	2017-9-1
降龙十巴掌	egon	知识产权没有用出版社	20	2019-7-5
葵花宝典	yuan	知识产权没有用出版社	33	2019–8-2
0.建表book,并向表中插入数据
create table book(
	书名 varchar(12),
    作者 varchar(12),
    出版社 varchar(12),
    价格 int unsigned not null,
    出版日期 date
);
insert into book values
('倚天屠龙记','egon','北京工业地雷出版社',70,'2019-7-1'),
('九阳神功','alex','人民音乐不好听出版社',5,'2018-7-4'),
('九阴真经','yuan','北京工业地雷出版社',62,'2017-7-12'),
('九阴白骨爪','jinxin','人民音乐不好听出版社',40,'2019–8-7'),
('独孤九剑','alex','北京工业地雷出版社',12,'2017-9-1'),
('降龙十巴掌','egon','知识产权没有用出版社',20,'2019-7-5'),
('葵花宝典','yuan','知识产权没有用出版社',33,'2019–8-2');

1.查询 egon 写的所有书和价格
select 书名,价格 from book where 作者='egon';
2.找出最贵的图书的价格
select 书名,价格 from book ;
3.求所有图书的均价
4.将所有图书按照出版日期排序
5.查询alex写的所有书的平均价格
6.查询人民音乐不好听出版社出版的所有图书
7.查询人民音乐出版社出版的alex写的所有图书和价格
8.找出出版图书均价最高的作者
9.找出最新出版的图书的作者和出版社
10.显示各出版社出版的所有图书
11.查找价格最高的图书,并将它的价格修改为50元
12.删除价格最低的那本书对应的数据
13.将所有alex写的书作业修改成alexsb
14.select year(publish_date) from book
自己研究上面sql语句中的year函数的功能,完成需求:
将所有2017年出版的图书从数据库中删除
15.有文件如下,使用python写代码将文件中的数据写入数据库
学python从开始到放弃|alex|人民大学出版社|50|2018-7-1
学mysql从开始到放弃|egon|机械工业出版社|60|2018-6-3
学html从开始到放弃|alex|机械工业出版社|20|2018-4-1
学css从开始到放弃|wusir|机械工业出版社|120|2018-5-2
学js从开始到放弃|wusir|机械工业出版社|100|2018-7-30

小练习2

键表准备

数据导入

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;

准备表、记录

mysql> create database db1;
mysql> use db1;
mysql> source /root/init.sql

查表

select * from class;#班级
+-----+--------------+
| cid | caption      |
+-----+--------------+
|   1 | 三年二班     |
+-----+--------------+
select * from course;#课程
+-----+--------+------------+
| cid | cname  | teacher_id |
+-----+--------+------------+
|   1 | 生物   |          1 |
+-----+--------+------------+
mysql> select * from score;#分数
+-----+------------+-----------+-----+
| sid | student_id | course_id | num |
+-----+------------+-----------+-----+
|   1 |          1 |         1 |  10 |
+-----+------------+-----------+-----+
mysql> select * from student;#学生
+-----+--------+----------+--------+
| sid | gender | class_id | sname  |
+-----+--------+----------+--------+
|   1 | 男     |        1 | 理解   |
+-----+--------+----------+--------+
mysql> select * from teacher;#老师
+-----+-----------------+
| tid | tname           |
+-----+-----------------+
|   1 | 张磊老师        |
+-----+-----------------+

1、查询男生、女生的人数;

select count(gender) from student group by gender;

2、查询姓“张”的学生名单;

select * from student where sname like '张%';

3、课程平均分从高到低显示

select avg(num) from  score group by  course_id order by avg(num) desc;

4、查询有课程成绩小于60分的同学的学号、姓名;

1查询小于60的的学生id
select student_id from score where num<60;
2利用学生id在学生表查姓名
select sid,sname from student where sid in (select student_id from score where num<60);

5、查询至少有一门课与学号为1的同学所学课程相同的同学的学号和姓名;

1先查出学号1的所学课程
select course_id from score where student_id=1;
2查分数表 只要符合 学的课程在1号同学就行 获取学生id
select student_id from score where course_id in (select course_id from score where student_id=1) and student_id !=1 group by student_id;
3学生id获取姓名
select sid,sname from student where sid in (select student_id from score where course_id in (select course_id from score where student_id=1) and student_id !=1 group by student_id);

6、查询出只选修了一门课程的全部学生的学号和姓名;

1先查学生id
select student_id from score group by student_id order by count(course_id)=1;
2id查姓名
select sid,sname from student where sid in (select student_id from score group by student_id order by count(course_id)=1);

7、查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;

select course_id,max(num),min(num) from score group by course_id;

8、查询课程编号“2”的成绩比课程编号“1”课程低的所有同学的学号、姓名;

1先查出课程编号1的学生信息
select * from score where course_id=1;
2查出课程编号2的学生信息
select * from score where course_id=2;
3连表查询 左外连接 利用学生id相同 找出学生id
select t1.student_id from (select * from score where course_id=1) t2 inner join (select * from score where course_id=2) t1 on t1.student_id = t2.student_id where t1.num<t2.num;
4学生id 找姓名
select sid,sname from student where sid in (select t1.student_id from (select * from score where course_id=1) t2 inner join (select * from score where course_id=2) t1 on t1.student_id = t2.student_id where t1.num<t2.num);

9、查询“生物”课程比“物理”课程成绩高的所有学生的学号;

1先查生物id
select cid from course where cname='生物';
2查物流id
select cid from course where cname='物理';
3利用id 查生物成绩
select * from score where course_id =(select cid from course where cname='生物');
3利用id 查物理成绩
select * from score where course_id =(select cid from course where cname='物理');
4连表 找出学生id
select t1.student_id from (select * from score where course_id =(select cid from course where cname='生物')) t2 inner join (select * from score where course_id =(select cid from course where cname='物理')) t1 on t1.student_id = t2.student_id where t1.num>t2.num ;
5 id找姓名
select sid,sname from student where sid in (select t1.student_id from (select * from score where course_id =(select cid from course where cname='生物')) t2 inner join (select * from score where course_id =(select cid from course where cname='物理')) t1 on t1.student_id = t2.student_id where t1.num<t2.num);

10、查询平均成绩大于60分的同学的学号和平均成绩;

1学生分组
select student_id,avg(num) from score group by student_id order by avg(num) >60;

11、查询所有同学的学号、姓名、选课数、总成绩;

1学生分组
select student_id,avg(num),count(course_id) from score group by student_id;
2连表
select t1.student_id,t1.pjnum,t1.zcourse,t2.sname from (select student_id,avg(num) as pjnum,count(course_id) as zcourse from score group by student_id) as t1 inner join (select * from student) t2 on t1.student_id=t2.sid;

12、查询姓“李”的老师的个数;

1先查姓李的老师id 在计数
select count(tid) from teacher where tname like '李%';

13、查询没学过“张磊老师”课的同学的学号、姓名;

1找到张磊老师id
select tid from teacher where tname='张磊老师';
2查询张磊老师教什么课
select cid from course where teacher_id=(select tid from teacher where tname='张磊老师');
3找学过的
select student_id from score where course_id in (select cid from course where teacher_id=(select tid from teacher where tname='张磊老师'));
4逆向思维
select sid,sname from student where sid not in (select student_id from score where course_id in (select cid from course where teacher_id=(select tid from teacher where tname='张磊老师')));


14、查询学过“1”并且也学过编号“2”课程的同学的学号、姓名;

1查询学过编号1的
select student_id from score where course_id=1;
2查询学过编号2的
select student_id from score where course_id=2;
3连表 找id
select t1.student_id from (select student_id from score where course_id=1) as t1 inner join (select student_id from score where course_id=2) as t2 on t1.student_id=t2.student_id;
4id找名字
select sid,sname from student where sid in (select t1.student_id from (select student_id from score where course_id=1) as t1 inner join (select student_id from score where course_id=2) as t2 on t1.student_id=t2.student_id);

15、查询学过“李平老师”所教的所有课的同学的学号、姓名;

select student_id from score where course_id in (select cid from course where teacher_id=(select tid from teacher where tname='张磊老师'));
id 找名字
select sid,sname from student where sid in (select student_id from score where course_id in (select cid from course where teacher_id=(select tid from teacher where tname='张磊老师')));

1、查询没有学全所有课的同学的学号、姓名;

1总课程数
select count(cid) from course;
2分组 找id
select student_id from score group by student_id having count(course_id)=(select count(cid) from course);
id 找名字
select sid,sname from student where sid in (select student_id from score group by student_id having count(course_id)=(select count(cid) from course));

2、查询和“2”号的同学学习的课程完全相同的其他同学学号和姓名;

id找课程 个数
select count(course_id) from score where student_id=2;
id找课程 名称
select course_id from score where student_id=2;
找出符合相同科目的学生 id
select student_id from score group by student_id having count(course_id)=(select count(course_id) from score where student_id=2);
#找不在的
select student_id from score where student_id in (select student_id from score group by student_id having count(course_id)=(select count(course_id) from score where student_id=2)) and course_id not in (select course_id from score where student_id=2);


3、删除学习“叶平”老师课的SC表记录;

4、向SC表中插入一些记录,这些记录要求符合以下条件:①没有上过编号“2”课程的同学学号;②插入“2”号课程的平均成绩;

5、按平均成绩从低到高显示所有学生的“语文”、“数学”、“英语”三门的课程成绩,按如下形式显示: 学生ID,语文,数学,英语,有效课程数,有效平均分;

语文id
select cid from course where cname='语文'
数学
select cid from course where cname='数学'
英语
select cid from course where cname='英语';

6、查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;
7、按各科平均成绩从低到高和及格率的百分数从高到低顺序;
8、查询各科成绩前三名的记录:(不考虑成绩并列情况)
9、查询每门课程被选修的学生数;
10、查询同名同姓学生名单,并统计同名人数;
11、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列;
12、查询平均成绩大于85的所有学生的学号、姓名和平均成绩;
13、查询课程名称为“数学”,且分数低于60的学生姓名和分数;
14、查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;
15、求选了课程的学生人数
16、查询选修“杨艳”老师所授课程的学生中,成绩最高的学生姓名及其成绩;
17、查询各个课程及相应的选修人数;
18、查询不同课程但成绩相同的学生的学号、课程号、学生成绩;
19、查询每门课程成绩最好的前两名;
20、检索至少选修两门课程的学生学号;
21、查询全部学生都选修的课程的课程号和课程名;
22、查询没学过“叶平”老师讲授的任一门课程的学生姓名;
23、查询两门以上不及格课程的同学的学号及其平均成绩;
24、检索“004”课程分数小于60,按分数降序排列的同学学号;
25、删除“002”同学的“001”课程的成绩;

1、查询所有的课程的名称以及对应的任课老师姓名
select * from teacher inner join emp on dep.id=emp.dep_id;
2、查询学生表中男女生各有多少人

3、查询物理成绩等于100的学生的姓名

4、查询平均成绩大于八十分的同学的姓名和平均成绩

5、查询所有学生的学号,姓名,选课数,总成绩

6、 查询姓李老师的个数

7、 查询没有报李平老师课的学生姓名

8、 查询物理课程比生物课程高的学生的学号

9、 查询没有同时选修物理课程和体育课程的学生姓名

10、查询挂科超过两门(包括两门)的学生姓名和班级

11 、查询选修了所有课程的学生姓名

12、查询李平老师教的课程的所有成绩记录

13、查询全部学生都选修了的课程号和课程名

14、查询每门课程被选修的次数

15、查询之选修了一门课程的学生姓名和学号

16、查询所有学生考出的成绩并按从高到低排序(成绩去重)

17、查询平均成绩大于85的学生姓名和平均成绩

18、查询生物成绩不及格的学生姓名和对应生物分数

19、查询在所有选修了李平老师课程的学生中,这些课程(李平老师的课程,不是所有课程)平均成绩最高的学生姓名

20、查询每门课程成绩最好的前两名学生姓名

21、查询不同课程但成绩相同的学号,课程号,成绩

22、查询没学过“叶平”老师课程的学生姓名以及选修的课程名称;

23、查询所有选修了学号为1的同学选修过的一门或者多门课程的同学学号和姓名;

24、任课最多的老师中学生单科成绩最高的学生姓名

答案在此 -----》https://www.cnblogs.com/Eva-J/articles/9760077.html

https://www.cnblogs.com/Eva-J/articles/9765370.html

第2题不会

原文地址:https://www.cnblogs.com/saoqiang/p/11423810.html