• 售前

  • 售后

热门帖子
入门百科

MSSQL表里连接(INNER JOIN)语句详解

[复制链接]
索支较 显示全部楼层 发表于 2021-10-25 20:16:40 |阅读模式 打印 上一主题 下一主题
在之前,我对MSSQL中的内毗连和外毗连所得出的数据集不是很清楚。这几天重新温习了一下SQL的书本,如今的思绪应该是很清楚了,如今把自己的理解发出来给各人温习下。渴望和我一样对SQL的毗连语句不太理解的朋友能够有所帮助。(发这么菜的教程,各位大大们别笑话偶了,呵:D )
有两个表A和表B。
表A布局如下:
Aid:int;标识种子,主键,自增ID
Aname:varchar
数据情况,即用select * from A出来的记载情况如下图1所示:


图1:A表数据
表B布局如下:
Bid:int;标识种子,主键,自增ID
Bnameid:int

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

图2:B表数据
为了把Bid和Aid加以区分,不让各人有误解,所以把Bid的起始种子设置为100。
有SQL基本知识的人都知道,两个表要做毗连,就必须有个毗连字段,从上表中的数据可以看出,在A表中的Aid和B表中的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.Bnameid与Select * 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:左毗连数据
分析:
           在语句中,A在B的左边,而且是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
           由此得出图5中A左毗连B的记载=图3公共部门记载集C+表A记载集A1,
           终极得出的结果图5中可以看出Bnameid及Bid非NULL的记载都为图3公共部门记载集C中的记载;Bnameid及Bid为NULL的Aid为1 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:右毗连数据

分析:
           在语句中,A在B的左边,而且是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
           由此得出图6中A右毗连B的记载=图3公共部门记载集C+表B记载集B1,
           终极得出的结果图6中可以看出Aid及Aname非NULL的记载都为图3公共部门记载集C中的记载;Aid及Aname为NULL的Aid为11的记载就是表B记载集B1中存在的Bnameid。

总结:
通过上面的运算讲授,信任很多人已经想到,上面的情况(包罗图3的关系图)分析的都只是A在B的左边的情况,
以下语句B在A的右边的又会出现什么情况呢??
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.Bnameid和select * from A Right JOIN B ON A.Aid=B.Bnameid所得出的记载集是一样的

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

第一次写类似教程的贴子,渴望和我一样对SQL的毗连语句不太理解的朋友能够有所帮助。谢谢各人支持。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作