SQL语法:join的用法总结
一、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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix