SQL内连接与外连接用法与区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL内连接与外连接用法与区别相关的知识,希望对你有一定的参考价值。

SQL内连接与外连接用法与区别

1、内连接:从结果表中删除与其他被连接表中没有匹配行的所有行。

2、外连接:返回每个满足第一个(顶端)输入与第二个(底端)输入的联接的行。

二、语法不同

1、内连接:select fieldlist from table1 [inner] join table2 on table1.column=table2.column

2、外连接:select * from dave a full join bl b on a .id = b .id;


三、注意事项不同

1、内连接:需要区分在嵌套查询中使用的any与all的区别,any相当于逻辑运算“||”而all则相当于逻辑运算“&&”

2、外连接:左表和右表都不做限制,所有的记录都显示,两表不足的地方用null 填充。 全外连接不支持(+)这种写法。


参考资料来源:百度百科-外连接

参考资料来源:百度百科-内连接

参考技术A 关键字: 左右连接

数据表的连接有:

1、内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现

2、外连接: 包括

(1)左外连接(左边的表不加限制)

(2)右外连接(右边的表不加限制)

(3)全外连接(左右两表都不加限制)

3、自连接(连接发生在一张基表内)

select a.studentno, a.studentname, b.classname

from students a, classes b

where a.classid(+) = b.classid;

STUDENTNO STUDENTNAM CLASSNAME

---------- ---------- ------------------------------

1 A 一年级一班

2 B 一年级二班

一年级三班

以上语句是右连接:

即"(+)"所在位置的另一侧为连接的方向,右连接说明等号右侧的所有

记录均会被显示,无论其在左侧是否得到匹配。也就是说上例中,无

论会不会出现某个班级没有一个学生的情况,这个班级的名字都会在

查询结构中出现。

反之:

select a.studentno, a.studentname, b.classname

from students a, classes b

where a.classid = b.classid(+);

STUDENTNO STUDENTNAM CLASSNAME

---------- ---------- ------------------------------

1 A 一年级一班

2 B 一年级二班

3 C

则是左连接,无论这个学生有没有一个能在一个班级中得到匹配的部门号,

这个学生的记录都会被显示。

select a.studentno, a.studentname, b.classname

from students a, classes b

where a.classid = b.classid;

这个则是通常用到的内连接,显示两表都符合条件的记录

总之,

左连接显示左边全部的和右边与左边相同的

右连接显示右边全部的和左边与右边相同的

内连接是只显示满足条件的!本回答被提问者采纳
参考技术B http://blog.163.com/cs_mayong/blog/static/9581317120096595410120/

看看就明白了

2020.03.14 内连接与外连接的区别

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

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

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

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

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

示例:

数据库版本:Oracle

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

技术图片

A.内连接

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

1
2
3
SELECT * 
FROM TESTA,TESTB
WHERE TESTA.A=TESTB.A

结果:

技术图片

B.外连接

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

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

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

1
2
3
4
SELECT *
FROM TESTA 
LEFT OUTER JOIN TESTB 
ON TESTA.A=TESTB.A

结果:

技术图片

三个表做左外链接:

1
2
3
4
5
6
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

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

1
2
3
4
SELECT *
FROM TESTA 
RIGHT OUTER JOIN TESTB 
ON TESTA.A=TESTB.A

技术图片

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

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

1
2
3
4
SELECT 
FROM TESTA 
FULL OUTER JOIN TESTB
ON TESTA.A=TESTB.A

结果:

技术图片

以上是关于SQL内连接与外连接用法与区别的主要内容,如果未能解决你的问题,请参考以下文章

SQL内连接与外连接的区别

2020.03.14 内连接与外连接的区别

SQL中的左连接与右连接,内连接有啥区别

内连接与外连接(全网最详细)

MySQL 内连接与外连接

一文让你彻底理解SQL连接查询