MySQL【知识改变命运】11

联合查询

  • [6. ⼦查询](#6. ⼦查询)
    • [6.1 语法](#6.1 语法)
    • [6.2 单⾏⼦查询](#6.2 单⾏⼦查询)
    • [6.3 多⾏⼦查询](#6.3 多⾏⼦查询)
    • [6.4 多列⼦查询](#6.4 多列⼦查询)
    • [6.5 在from⼦句中使⽤⼦查询](#6.5 在from⼦句中使⽤⼦查询)
  • [7. 合并查询](#7. 合并查询)
    • [7.1 创建新表并初始化数据](#7.1 创建新表并初始化数据)
    • [7.2 Union](#7.2 Union)
    • [7.3 Union all](#7.3 Union all)
  • [8. 插⼊查询结果](#8. 插⼊查询结果)
    • [8.1 语法](#8.1 语法)
    • [8.2 ⽰例](#8.2 ⽰例)

6. ⼦查询

⼦查询是把⼀个SELECT语句的结果当做别⼀个SELECT语句的条件,也叫嵌套查询

6.1 语法

sql 复制代码
select * from table1 where col_name1 {= | IN} (
 select col_name1 from table2 where col_name2 {= | IN} [(
 select ...)
 ] ...
)

6.2 单⾏⼦查询

嵌套的查询中只返回⼀⾏数据

• ⽰例:查询与"不想毕业"同学的同班同学

sql 复制代码
mysql> select * from student where class_id = (select class_id from student 
where name = '不想毕业');
  1. 确定参与查询表:学生表

  2. 先查出不想毕业这位同学的班级编号

  3. 在学生表中查出与不想毕业的同班同学,过滤条件是class_id=2

  4. 组合成子查询的方式

  5. 过滤掉不想毕业这位同学的记录

6.3 多⾏⼦查询

嵌套的查询中返回多⾏数据,使⽤[NOT] IN关键字

• ⽰例:查询"MySQL"或"Java"课程的成绩信息

sql 复制代码
select * from score where score.course_id in (select course.id from course where course.`name`='MySQL' or name='java' );
  1. 确定参与查询的表:
    课程表,成绩表。
  2. 先查询课程表中的课程信息
  1. 通过课程编号在分数表里中查询对应的分数
  1. 合并成子查询的方式

再查询不包括mysql和java的成绩

6.4 多列⼦查询

单⾏⼦查询和多⾏⼦查询都只返回⼀列数据,多列⼦查询中可以返回多个列的数据,外层查询与嵌套

的内层查询的列要匹配

• ⽰例:查询重复录⼊的分数

1.对重复的列进行分组并计算这组重复的个数

  1. 进行对重复数据的筛选
  1. 确定内层条件并加入到外层查询当中

6.5 在from⼦句中使⽤⼦查询

当⼀个查询产⽣结果时,MySQL⾃动创建⼀个临时表,然后把结果集放在这个临时表中,最终返回

给⽤⼾,在from⼦句中也可以使⽤临时表进⾏⼦查询或表连接操作
• ⽰例:查询所有⽐"Java001班"平均分⾼的成绩信息

三表关联

  1. 再用成绩表中的真实成绩与平均分做比较


  • 这里小总结一下:用子查询返回的值,用于where 子句里面,用子查询生成的临时表 用于from 子句中。

7. 合并查询

  • 在实际应⽤中,为了合并多个select操作返回的结果,可以使⽤集合操作符 union,union all

7.1 创建新表并初始化数据



7.2 Union

  • 该操作符⽤于取得两个结果集的并集。当使⽤该操作符时,会⾃动去掉结果集中的重复⾏。

  • ⽰例:查询student表中 id < 3 的同学和student1表中的所有同学

  • 还可以单表操作

7.3 Union all

该操作符⽤于取得两个结果集的并集。当使⽤该操作符时,不会去掉结果集中的重复⾏

如果查询结果来自多个表,那么推荐使用合并查询

8. 插⼊查询结果

8.1 语法

sql 复制代码
INSERT INTO table_name [(column [, column ...])] SELECT ...

8.2 ⽰例

• 将student表中C++001班的学⽣复制到student1表中

student1插入前的原表。

student表中C++001班的数据

语句插入

插入成功:

相关推荐
xvch1 小时前
Kotlin 2.1.0 入门教程(二十五)类型擦除
android·kotlin
夜泉_ly1 小时前
MySQL -安装与初识
数据库·mysql
qq_529835352 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New5 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6755 小时前
数据库基础1
数据库
我爱松子鱼5 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo5 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser6 小时前
【SQL】多表查询案例
数据库·sql
Galeoto6 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)7 小时前
MySQL主从架构
服务器·数据库·mysql