数据库 左连接,右连接,全连接,内连接

准备:

分别创建TB A,B. 插入一些测试数据。

TB_A

数据库 左连接,右连接,全连接,内连接_第1张图片

TB_B

数据库 左连接,右连接,全连接,内连接_第2张图片

1.内链接 (inner join)

内连接是一种一一映射关系,就是两张表都有的才能显示出来

这里写图片描述

代码例子:

select * from TB_A a inner join TB_B b on a.name=b.name

数据库 左连接,右连接,全连接,内连接_第3张图片

扩展:这里我突然联想到,其实这个查询也可以用以下语句来执行,从而得到同样的效果。

select * from TB_A a,TB_B b where a.name=b.name

那内连接和这个条件查询有何区别呢?通过三方查询,从某地得到一个解答不知是否完全正确(有望高手进一步解答),但他的解答目前符合一切条件。

解答如下:内连接通过on 关键字先对两张表内容进行了条件匹配筛选,在查询出所有内容。而where语句先便利了AB表的内容再通过where条件进行筛选。所以一般来说内连接先缩小了查询范围,从而执行效率比where条件来的要高。

实际情况的执行时间也是满足的

数据库 左连接,右连接,全连接,内连接_第4张图片

 

2.左连接(left join)

左连接是左边表的所有数据都有显示出来,右边的表数据只显示共同有的那部分,没有对应的部分只能补null显示,所谓的左边表其实就是指放在left join的左边的表.

这里写图片描述

代码例子:

select * from TB_A a left join TB_B b on a.name=b.name;

数据库 左连接,右连接,全连接,内连接_第5张图片

 

3.右连接(right join)

右连接是右边表的所有数据都有显示出来,左边的表数据只显示共同有的那部分,没有对应的部分只能补null显示,所谓的右边表其实就是指放在right join的右边的表.

这里写图片描述

代码例子:

select * from TB_A a right join TB_B b on a.name=b.name;

数据库 左连接,右连接,全连接,内连接_第6张图片

 

4.外连接,全连接(outer join)

查询出左表和右表所有数据,但会去除两表的重复数据

这里写图片描述

代码例子:

select * from TB_A a full join TB_B b on a.name=b.name;

由于我用的是mysql数据库,突然发现mysql并不支持全连接,只能通过一下解决

左连接+右连接-重复=全连接

代码例子:

select * from TB_A a left join TB_B b on a.name=b.name union select * from TB_A a right join TB_B b on a.name=b.name;

数据库 左连接,右连接,全连接,内连接_第7张图片

 

5.左连接不包含内连接

这个查询是只查询左边表有的数据,共同有的也不查出来

这里写图片描述

代码例子:

select * from TB_A a left join TB_B b on a.name=b.name where b.name is null;

数据库 左连接,右连接,全连接,内连接_第8张图片

 

6.右连接不包含内连接

这个查询是只查询右边表有的数据,共同有的也不查出来

代码例子:

select * from TB_A a right join TB_B b on a.name=b.name where a.name is null;

数据库 左连接,右连接,全连接,内连接_第9张图片

 

7.外连接不包含内连接

查询左右表各自拥有的那部分数据

这里写图片描述

代码例子:

select * from TB_A a right join TB_B b on a.name=b.name where a.name is null union select * from TB_A a left join TB_B b on a.name=b.name where b.name is null;

你可能感兴趣的:(数据库,MYSQL)