内连接与外连接的区别是什么?_数据库外连接和内连接的区别

内连接与外连接的区别是什么?_数据库外连接和内连接的区别有两个表A和表B。表A结构如下:Aid:int;标识种子,主键,自增IDAname:varchar数据情况,即用select*fromA出来的记录情况如下图1所示:图1:A表数据表B结构如下:Bid:int;标识种子,主键,自增IDBnameid:int数据情况,即用select*fromB出来的记录情况如下图2所示:图2:B表数据为了把Bid和Aid加以区分,不让大家有误解,所以把B…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

有两个表A和表B
A结构如下:
Aidint;标识种子,主键,自增ID
Anamevarchar

数据情况,即用select * from A出来的记录情况如下图1所示:

内连接与外连接的区别是什么?_数据库外连接和内连接的区别
1:A表数据

B结构如下:
Bidint;标识种子,主键,自增ID
Bnameidint

数据情况,即用select * from B出来的记录情况如下图2所示:

内连接与外连接的区别是什么?_数据库外连接和内连接的区别
2:B表数据

为了把BidAid加以区分,不让大家有误解,所以把Bid的起始种子设置为100
SQL基本知识的人都知道,两个表要做连接,就必须有个连接字段,从上表中的数据可以看出,在A表中的AidB表中的Bnameid就是两个连接字段。
下图3说明了连接的所有记录集之间的关系:

内连接与外连接的区别是什么?_数据库外连接和内连接的区别

3:连接关系图

现在我们对内连接和外连接一一讲解。
1.内连接:利用内连接可获取两表的公共部分的记录,即图3的记录集C
语句如下:Select * from A JOIN B ON A.Aid=B.Bnameid
运行结果如下图4所示:

内连接与外连接的区别是什么?_数据库外连接和内连接的区别
4:内连接数据

其实select * from A,B where A.Aid=B.BnameidSelect * from A JOIN B ON A.Aid=B.Bnameid的运行结果是一样的。
2.外连接:外连接分为两种,一种是左连接(Left JOIN)和右连接(Right JOIN
   (1)左连接(Left JOIN):即图3公共部分记录集C+表A记录集A1。     
      语句如下:select * from A Left JOIN B ON A.Aid=B.Bnameid
      运行结果如下图5所示:

内连接与外连接的区别是什么?_数据库外连接和内连接的区别
5:左连接数据

      说明:
            在语句中,AB的左边,并且是Left Join,所以其运算方式为:A左连接B的记录=3公共部分记录集C+表A记录集A1
            在图3中即记录集C中的存在的Aid为:2 3 6 7 8           
            图1中即表A所有记录集A中存在的Aid为:1 2 3 4 5 6 7 8 9
            表A记录集A1中存在的Aid=(1中即A表中所有Aid)-(3中即记录集C中存在的Aid),最终得出为:1 4 5 9
            由此得出图5A左连接B的记录=3公共部分记录集C+表A记录集A1,
            最终得出的结果图5中可以看出BnameidBidNULL的记录都为图3公共部分记录集C中的记录;BnameidBidNULLAid1 4 5 9的四笔记录就是表A记录集A1中存在的Aid

   (2)右连接(Right JOIN):即图3公共部分记录集C+表B记录集B1
      语句如下:select * from A Right JOIN B ON A.Aid=B.Bnameid
      运行结果如下图6所示:

内连接与外连接的区别是什么?_数据库外连接和内连接的区别
6:右连接数据

      说明:
            在语句中,AB的左边,并且是Right Join,所以其运算方式为:A右连接B的记录=3公共部分记录集C+表B记录集B1
            在图3中即记录集C中的存在的Aid为:2 3 6 7 8           
            图2中即表B所有记录集B中存在的Bnameid为:2 3 6 7 8 11
            表B记录集B1中存在的Bnameid=(2中即B表中所有Bnameid)-(3中即记录集C中存在的Aid),最终得出为:11
            由此得出图6A右连接B的记录=3公共部分记录集C+表B记录集B1,
            最终得出的结果图6中可以看出AidAnameNULL的记录都为图3公共部分记录集C中的记录;AidAnameNULLAid11的记录就是表B记录集B1中存在的Bnameid
     
总结:

通过上面的运算解说,相信很多人已经想到,上面的情况(包括图3的关系图)说明的都只是AB的左边的情况,
以下语句BA的右边的又会出现什么情况呢??
select * from B Left JOIN A ON A.Aid=B.Bnameid
select * from B Right JOIN A ON A.Aid=B.Bnameid

其实对图3左右翻转一下就可以得出以下结论:
select * from B Left JOIN A ON A.Aid=B.Bnameidselect * from A Right JOIN B ON A.Aid=B.Bnameid所得出的记录集是一样的

select * from B Right JOIN A ON A.Aid=B.Bnameidselect * from A Left JOIN B ON A.Aid=B.Bnameid所得出的记录集也是一样的。


你是要弄清楚区别在什么地方还是单纯想要文字说明

文字说明的楼上说了一大堆了,不说了。

弄个例题,直观一点。两个表:

stu

id  name   

1,  Jack

2,  Tom

3,  Kity

4,  nono

exam

id   grade

1,   56

2,   76

11,  89

内连接 (显示两表id匹配的)

select stu.id,exam.id,stu.name, exam.grade from stu inner join exam on stu.id=exam.id

stu.id   exam.id  name     grade

——————————–

1 1 Jack 56

2 2 Tom 76

左连接(显示join 左边的表的所有数据,exam只有两条记录,所以stu.id,grade 都用NULL 显示)

select stu.id,exam.id,stu.name, exam.grade from stu left join exam on stu.id=exam.id

1 1 Jack 56

2 2 Tom 76

3 NULL Kity NULL

4 NULL nono NULL

右连接(与作连接相反,显示join右边表的所有数据)

select stu.id,exam.id,stu.name, exam.grade from stu right join exam on stu.id=exam.id

1 1 Jack 56

2 2 Tom 76

NULL 11 NULL 89

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/184264.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 历代iPhone的分辨率[通俗易懂]

    历代iPhone的分辨率设备 逻辑分辨率(point) 物理分辨率(pixel) 屏幕尺寸 缩放因子 PPI iPhone2G 320×480 320×480 3.5寸 @1x 163 iPhone3 320×480 320×480 3.5寸 @1x 163 iPhone…

  • 如何配置pytorch_pytorch如何下载

    如何配置pytorch_pytorch如何下载1.好像不支持python3.8。直接从setting里面安装时不行的,按其它教程(https://blog.csdn.net/lyz21/article/details/104295042)从官网https://pytorch.org/get-started/locally/,拷贝链接用pip下载,一直报找不到版本。后来发现,python3.8的原因,改成python3.7可以了,但会一直连接超时。2.发现要下载的其实是这两个文件:点开下面的两个链接,用下载软件下载了,我下到了e盘,直接pip

    2022年10月31日
  • 字典树

    字典树

  • 第二套17

    第二套17

  • Android 文件夹_安卓文档在哪个文件夹

    Android 文件夹_安卓文档在哪个文件夹【文件夹功能简介】/system/app这个里面主要存放的是常规下载的应用程序,可以看到都是以APK格式结尾的文件。在这个文件夹下的程序为系统默认的组件,自己安装的软件将不会出现在这里,而是/data/文件夹中。/system/bin这个目录下的文件都是系统的本地程序,从bin文件夹名称可以看出是binary二进制的程序,里面主要是Linux系统自带的组件(命令)/system/etc从文件夹名称来看保存的都是系统的配置文件,比如APN接入点设置等核心配置。/system/fonts字体文件夹,除了标准字体

    2022年10月16日
  • IT视频资源分享列表(二)[通俗易懂]

    IT视频资源分享列表(二)

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号