MySQL多表查询的案例详解

多表查询

案列说明

笛卡尔积的理解

每个员工和每个部门匹配了一遍(查出的条目数=id数*department数)

错误原因:缺少连接条件

笛卡尔积的解决

编写连接条件: 表1.列 = 表二.列(若多个表连接,至少要用n-1个连接条件)

注:如果要显示的列在要查询的表中名字一样,则要表明,是出自哪个表, eg: employees.name

​ 建议在多表查询时,标明显示的是哪个表的信息 (优化)

优化:可以在from后使用表的别名,但是一旦使用别名,后续就一定要都用别名

多表查询的分类

等值连接和非等值连接

  • 等值连接:上述的带有=的
  • 非等值连接:没有=的

自连接和非自连接

  • 非自链接:表1和表2连接
  • 自链接:表1和自己连接

内连接和外连接

  • 内连接:合并含有同一列的表,结果不包括一个表与另一个表不匹配打的行
  • 外连接:合并含有同一列的表,结果除了内连接的结果还查询不匹配的行

外连接的分类:左外连接(左表多,补右边),右外连接(右表多,补左边),满外连接

sql92:使用(+)创建连接

内连接:见上

外连接:左表有数据不匹配,在右表加(+);反之,在左表加(+),但是mysql不支持

sql99:使用join…on的方式

内连接

外连接

使用outer join…on…

  • 左外连接:left outer join
  • 右外连接:right outer join
  • 满外连接:full outer join(mysql不支持)

umion的使用

合并查询结果

  • ​ union操作符

两个查询结果的并集,去重(效率低)

  • union all操作符(推荐)

​ 两个查询结果的并集,不去重(效率高)

7种sql joins的实现

中图(内连接):

左上图(左外连接):

右上图(右外连接):

左中图:

右中图:

左下图(满外连接):

右下图:

sql语法新特性

自然连接

使用关键字:natural join(不灵活),自动查询表中所有相同字段,然后进行等值连接

using连接(不适用于自连接)

使用关键字:using(同名字段),将表中相同名字的字段自动等值连接

到此这篇关于mysql多表查询的文章就介绍到这了,更多相关mysql多表查询内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐