准备:
分别创建TB A,B. 插入一些测试数据。
TB_A
TB_B
内连接是一种一一映射关系,就是两张表都有的才能显示出来
代码例子:
select * from TB_A a inner join TB_B b on a.name=b.name
扩展:这里我突然联想到,其实这个查询也可以用以下语句来执行,从而得到同样的效果。
select * from TB_A a,TB_B b where a.name=b.name
那内连接和这个条件查询有何区别呢?通过三方查询,从某地得到一个解答不知是否完全正确(有望高手进一步解答),但他的解答目前符合一切条件。
解答如下:内连接通过on 关键字先对两张表内容进行了条件匹配筛选,在查询出所有内容。而where语句先便利了AB表的内容再通过where条件进行筛选。所以一般来说内连接先缩小了查询范围,从而执行效率比where条件来的要高。
实际情况的执行时间也是满足的
左连接是左边表的所有数据都有显示出来,右边的表数据只显示共同有的那部分,没有对应的部分只能补null显示,所谓的左边表其实就是指放在left join的左边的表.
代码例子:
select * from TB_A a left join TB_B b on a.name=b.name;
右连接是右边表的所有数据都有显示出来,左边的表数据只显示共同有的那部分,没有对应的部分只能补null显示,所谓的右边表其实就是指放在right join的右边的表.
代码例子:
select * from TB_A a right join TB_B b on a.name=b.name;
查询出左表和右表所有数据,但会去除两表的重复数据
代码例子:
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;
这个查询是只查询左边表有的数据,共同有的也不查出来
代码例子:
select * from TB_A a left join TB_B b on a.name=b.name where b.name is null;
这个查询是只查询右边表有的数据,共同有的也不查出来
代码例子:
select * from TB_A a right join TB_B b on a.name=b.name where a.name is null;
查询左右表各自拥有的那部分数据
代码例子:
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;