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

内连接与外连接的区别是什么?_数据库外连接和内连接的区别有两个表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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Composer 是什么

    Composer 是什么

    2021年10月11日
    62
  • MPEG-2_mpeg编码模式包括

    MPEG-2_mpeg编码模式包括作者:haibara来源:pcicp.com本FAQ由(haibara)翻译,期间受到kaito_mkid(pcicp)帮助,在此感谢,由于Newbie的关系,如有翻译错误,还请各位指出,由Doom9的bond编撰的原文。译者注:基本专业名称我都以小括号形式加以解释,详细信息请自行查阅资料。什么是MPEG-4?MPEG-4(ISO14496)是由制定了我们熟知的MPEG-1(MP3,…

    2026年1月26日
    6
  • PHP json 类型「建议收藏」

    PHP json 类型「建议收藏」有时候需要用json的格式返回数据,json是一个很常用的数据传输方式。下面是一个最简单的例子。就是说只需要设置一下文档类型是json的就可以了。‘helloworld’,’2’=>’linuxworld’);$show=j

    2022年7月26日
    8
  • matlab香农编码「建议收藏」

    matlab香农编码「建议收藏」1、读入图像使用imread()函数读入图像,由于m文件和图像放在同一目录下,故采用相对路径。img=imread(‘1.png’);2、统计灰度值使用imhist()函数,对图像的灰度值在[0,255]上做统计,统计每个灰度值出现的概率size()函数用来计算图像的大小。num=imhist(img);[m,n]=size(img);px=num/(m*n)…

    2025年10月23日
    4
  • 20道经典Redis面试题

    20道经典Redis面试题前言整理了 20 道经典 Redis 面试题 希望对大家有帮助 1 什么是 Redis 它主要用来什么的 Redis 英文全称是 RemoteDictio 远程字典服务 是一个开源的使用 ANSIC 语言编写 支持网络 可基于内存亦可持久化的日志型 Key Value 数据库 并提供多种语言的 API 与 MySQL 数据库不同的是 Redis 的数据是存在内存中的 它的读写速度非常快 每秒可以处理超过 10 万次读写操作 因此 redis 被广泛应用于缓存 另外 Redis 也经常用来做分布式锁

    2025年8月31日
    4
  • python导入xml文件_python爬虫写入excel

    python导入xml文件_python爬虫写入excel最近在使用Testlink时,发现导入的用例是xml格式,且没有合适的工具转成excel格式,xml使用excel打开显示的东西也太多,网上也有相关工具转成csv格式的,结果也不合人意。那求人不如尔己,自己写一个吧需要用到的模块有:xml.dom.minidom(python自带)、xlwt使用版本:python:2.7.5xlwt:1.0.0一、先分析TestlinkXML格式:这是一个有两级…

    2022年8月22日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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