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班的数据

语句插入

插入成功:

相关推荐
Android系统攻城狮14 小时前
Android ALSA进阶之处理PCM的ioctl命令snd_pcm_lib_ioctl:用法实例(一百)
android·pcm·alsa·音频进阶
2501_9418059320 小时前
在大阪智能零售场景中构建支付实时处理与高并发顾客行为分析平台的工程设计实践经验分享
数据库
李慕婉学姐20 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
珠海西格电力20 小时前
零碳园区有哪些政策支持?
大数据·数据库·人工智能·物联网·能源
哈里谢顿21 小时前
记录一次sql优化记录
mysql
数据大魔方21 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
Chasing Aurora21 小时前
数据库连接+查询优化
数据库·sql·mysql·prompt·约束
倔强的石头_21 小时前
【金仓数据库】ksql 指南(六)—— 创建与管理用户和权限(KingbaseES 安全控制核心)
数据库
诸神黄昏EX1 天前
Android Build系列专题【篇六:VINTF机制】
android
小熊officer1 天前
Python字符串
开发语言·数据库·python