join 常见的用法有

目录

left join (left outer join)

right join (right outer join)

join (inner join)

full join(full outer join 、outer join)

cross join


说明:left join 就是 left outer join、 right join 就是 right outer join、 join 就是 inner join 、full join 就是 full outer join 或者 outer join,他们就是简写而已!

 

下面来个简单的例子,让我们理解下他们分别是什么样的。

先建两个非常简单的表  table_a 、table_b ,表结构如下:

后面连接用的字段是 aId  和  bId   ,他们有4行是有相同的值的,然后每个表有一行是不同的

 

left join(left outer join)

左连接,表 table_a 左连接表 table_b ,表示以表 table_a 为主,关联上表 table_b 的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据,其余没有的为null

select * from table_a a left join table_b b on a.aId = b.bId;

语句查询结果如下:

right join(right outer join)

右连接,表 table_a 右连接表 table_b ,表示以表 table_b 为主,关联查询表 table_a 的数据,查出来的结果显示右边的所有数据,然后左边显示的是和右边有交集部分的数据,其余没有的为null

select * from table_a a right join table_b b on a.aId = b.bId;

语句查询结果如下:

join(inner join)

内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联(on 条件不满足)就不显示出来

select * from table_a a inner join table_b b on a.aId = b.bId;

语句查询结果如下:

 

full join(full outer join 、outer join)

外连接,就是求两个表集合的并集。从笛卡尔积的角度讲就是从笛卡尔积中挑出ON子句条件成立的记录,然后加上左表中剩余的记录,最后加上右表中剩余的记录

mySql 不支持 full join ,下面语句在 mySql 下会运行报错!

select * from table_a a full join table_b b on a.aId = b.bId;

因为外连接,他还有一种概念的说法是:left join 和 right join 的结果加起来再去重

所以可以用 union 连接 left join 和 right join 的结果来替换 outer join

(注意是 union,不是 union all)

select * from table_a a left join table_b b on a.aId = b.bId
union 
select * from table_a a right join table_b b on a.aId = b.bId;

查询结果如下:

select * from table_a a outer join table_b b on a.aId = b.bId;

 

cross join

交叉连接,就是得出两个表的笛卡尔积,这个在实际开发中用得很少

注意:cross join 后面是不要加 on 条件的

说明:在 mysql 中,如果你用 cross join 后面跟 on 条件,那他跟 join 的效果是一样的

select * from table_a cross join table_b

查询结果如下:

 

 

 

 

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐