SQL语法:join的用法总结

本文介绍了SQL中的几种表连接方式:LEFTJOIN显示左侧表所有数据及与右侧表的交集;RIGHTJOIN反之;INNERJOIN显示两表交集数据;OUTERJOIN(全连接)在MySQL中需用LEFTJOIN和RIGHTJOIN组合实现;CROSSJOIN则产生笛卡尔积。这些连接方法在数据库查询中起到关键作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、LEFT 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(右连接)

作用:右连接,表 table_a 右连接表 table_b ,表示以表 table_b 为主,关联查询表 table_a 的数据,查出来的结果显示右边的所有数据,然后左边显示的是和右边有交集部分的数据,其余没有的为null。
示例:select * from table_a A right join table_b B on A.aId = B.bId;

三、INNER JOIN(内连接)
作用:内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联(on 条件不满足)就不显示出来。
示例:select * from table_a A inner join table_b B on A.aId = B.bId;

四、FULL JOIN(外连接->OUTER JOIN)
作用:外连接,就是求两个表集合的并集。从笛卡尔积的角度讲就是从笛卡尔积中挑出ON子句条件成立的记录,然后加上左表中剩余的记录,最后加上右表中剩余的记录。
示例:select * from table_a A full join table_b B on A.aId = B.bId;
注意事项:mySql 不支持 full join ,上述语句在 mySql 下会运行报错!
解决办法:因为外连接,他还有一种概念的说法是:left join 和 right join 的结果加起来再去重,所以可以用 union 连接 left join 和 right join 的结果来替换 outer join。
解决示例: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;

五、CROSS JOIN(交叉连接)

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

注意:cross join 后面是不要加 on 条件的,在 mysql 中,如果你用 cross join 后面跟 on 条件,那他跟 join 的效果是一样的。
示例:select * from table_a cross join table_b
本文章来源于网络,版权归原作者所有,如果地推平台本站文章侵犯了您的权益,请联系我们删除。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dituirenwu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值