2020.03.14 内连接与外连接的区别
Posted aojie
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 |
结果:
以上是关于2020.03.14 内连接与外连接的区别的主要内容,如果未能解决你的问题,请参考以下文章