MySQL left join、right join 和 join 的区别

原文:【MySQL】left join、right join 和 join 的区别。简单修改。

left join、join、right join 和 inner join 等各种 join 的区别?网上搜,最常见的就是一张图解图,如下:

img

看图还是不懂,需要动手。

首先,我们先来建两张表,第一张表命名为 kemu,第二张表命名为 score:

imgimg

一、left join

顾名思义,就是“左连接”,表 1 左连接表 2,以左为主,表示以表 1 为主,关联上表 2 的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下:

select
*
from
kemu
left join score on kemu.id = score.id

结果集:

imgimg

二、right join

“右连接”,表 1 右连接表 2,以右为主,表示以表 2 为主,关联查询表 1 的数据,查出表 2 所有数据以及表 1 和表 2 有交集的数据,如下:

select
*
from
kemu
right join score on kemu.id = score.id

结果集:

imgimg

三、join

join,其实就是“inner join”,为了简写才写成 join,两个是表示一个的,内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,这个用的情况也是挺多的,如下

select
*
from
kemu
join score on kemu.id = score.id

结果集:

imgimg

以上就是三种连接的区别!

另:left join 是 left outer join 的简写、right join 是 right outer join 的简写。

参考:tsql - LEFT JOIN vs. LEFT OUTER JOIN in SQL Server - Stack Overflow

posted @   Higurashi-kagome  阅读(102)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
点击右上角即可分享
微信分享提示