数据库的内连接和外连接有什么区别?

数据库的内连接和外连接有什么区别?,第1张

内连接:指连接结果仅包含符合连接条件的行,参与连接的两个表都应该符合连接条件。

外连接:连接结果不仅包含符合连接条件的行同时也包含自身不符合条件的行。包括左外连接、右外连接和全外连接。

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是存储和管理数据,而转变成用户所需要的各种数据管理的方式。数据库有很多种类型,从最简单的存储有各种数据的表格到能够进行海量数据存储的大型数据库系统都在各个方面得到了广泛的应用。

在信息化社会,充分有效地管理和利用各类信息资源,是进行科学研究和决策管理的前提条件。数据库技术是管理信息系统、办公自动化系统、决策支持系统等各类信息系统的核心部分,是进行科学研究和决策管理的重要技术手段。

内连接:指连接结果仅包含符合连接条件的行,参与连接的两个表都应该符合连接条件。

外连接:连接结果不仅包含符合连接条件的行同时也包含自身不符合条件的行。包括左外连接、右外连接和全外连接。

左外连接:左边表数据行全部保留,右边表保留符合连接条件的行。

右外连接:右边表数据行全部保留,左边表保留符合连接条件的行。

全外连接:左外连接 union 右外连接。

示例:

数据库版本:Oracle

表TESTA,TESTB,TESTC,各有A, B两列。

A.内连接

内连接,即最常见的等值连接,例:

SELECT * 

FROM TESTA,TESTB

WHERE TESTA.A=TESTB.A

结果:

B.外连接

外连接分为左外连接,右外连接和全外连接。

1.  左外连接 left outer join 或者 left join

左外连接就是在等值连接的基础上加上主表中的未匹配数据,例:

SELECT *

FROM TESTA 

LEFT OUTER JOIN TESTB 

ON TESTA.A=TESTB.A

结果:

三个表做左外链接:

SELECT *

FROM TESTA 

LEFT OUTER JOIN TESTB 

ON TESTA.A=TESTB.A

LEFT OUTER JOIN TESTC

ON TESTA.A=TESTC.A

结果:

2. 右外连接 right outer join 或者 right join

右外连接是在等值连接的基础上加上被连接表的不匹配数据

SELECT *

FROM TESTA 

RIGHT OUTER JOIN TESTB 

ON TESTA.A=TESTB.A

3.全外连接 full outer join 或者 full join

全外连接是在等值连接的基础上将左表和右表的未匹配数据都加上。

SELECT * 

FROM TESTA 

FULL OUTER JOIN TESTB

ON TESTA.A=TESTB.A

结果:

内连接:返回2个表中完全符合条件的记录,结果集中每个表的字段内容均来自各自的表;

外连接:返回2个表中完全符合条件的记录,再加上2个表中各自的记录,结果集中的字段只有一个表中有记录时,另一个表中的字段均使用空值null填写。

例如A表:

ID user partmentID

1 aaa 3

2 bbb 3

3 ccc (null)

B表:

parmentID PartmentName

3 pm001

4 pm002

内连接结果:select A.user B.PartmentName from A inner join B on A.partmentID = B.partmentID

user PartmentName

aaapm001

bbbpm001

外连接结果:select A.user B.PartmentName from A outer join B on A.partmentID = B.partmentID

user PartmentName

aaapm001

bbbpm001

ccc (null)比内连接多出来的记录,PartmentName字段是空值

(null) pm002 比内连接多出来的记录,user字段是空值

内连接在多是应用环境下使用,只有极少是使用外连接:比如同类数据的对比就可以使用外连接,比较两人统计的同一个价格表,为了对比两份数据的一致性,可以使用外连接。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9991765.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存