之前我们给大家介绍过MySQL子查询与多表联合查询 MySQL子查询的基本使用方法(四)、关于MySQL多表联合查询,你真的会用吗?、关于MySQL内连接与外连接用法,全都在这里了!本节课我们想讲讲多表联查询与子查询的区别与联系。
01
多表联合查询
经过前几节课的讲解,大家应该知道了,多表联合查询包括内连接查询与外连接查询。 内连接查询表示左右两边需同时满足连接条件,它取的是两者的交集。 外连接查询包括左外连接、右外连接以及union/union all 连接。
左外连接以左表为基础,根据ON后给出的连接条件将左右两表连接起来,同时结果会将左表所有的记录列出,而右表只列出ON后与左表满足条件的部分。
右外连接以右表为基础,根据ON后给出的连接条件将左右两表连接起来。结果会将右表所有的记录列出,而左表只列出ON后与右表满足条件的部分。
在MySQL中没有全外连接,但可以使用UNION/UNION ALL 对两个表取并集。但UNION会对合并结果去重,UNION ALL不会去重。
02
子查询
在前面的课程中我们只给大家介绍了带IN关键字的子查询,其实在MySQL中,子查询有很多种,例如EXISTS、ANY以及多种比较运算符=、!=、>、<等都属于子查询的范畴。其中最常用的子查询分别是带关键字IN/EXISTS/以及多种运算符的子查询。使用起来也简单,这里不再举例说明。重点说一下带关键词IN与关键词EXISTS子查询执行过程中的区别。
带EXISTS关键词的执行原理:
1、exists子查询语句中会优先执行主查询语句,常见语法结构:where exists (子查询)。exists会根据其后的子查询语句返回结果,判断条件真假;
2、子查询如果返回结果,则exists条件成立,条件成立则输出主查询结果记录,否则不返回任何结果,表示exists条件不成立。
带IN关键词的执行原理:
1、IN的执行顺序与exists不一样,IN子查询会优先产生查询结果集;
2、然后主查询再去子查询结果集中查找符合条件的结果输出,反之则不输出。
03
子查询与多表联合查询的区别
子查询:
多表联合查询:
总结:
多表联合查询通过建立临时表,减少查询数据的次数,同时可以利用索引提高查询效率,因此多表联合查询比子查询效率更高!!!