Oracle数据库之SQL内连接、外连接以及(+)号用法
小标 2019-05-10 来源 : 阅读 1842 评论 0

摘要:本文主要向大家介绍了Oracle数据库之SQL内连接、外连接以及(+)号用法,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。

本文主要向大家介绍了Oracle数据库之SQL内连接、外连接以及(+)号用法,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。

Oracle数据库之SQL内连接、外连接以及(+)号用法

A.内连接


内连接,即最常见的等值连接。(两边的表都加限制)


B.外连接


外连接分为左外连接,右外连接和全外连接。
左外连接:左表不加限制,保留左表的数据,匹配右表,右表没有匹配到的行中的列显示为null。(左外连接就是在等值连接的基础上加上主表中的未匹配数据)
右外连接:右表不加限制,保留右表的数据。匹配左表,左表没有匹配到的行中列显示为null。(右外连接就是在等值连接的基础上加上匹配表的不匹配数据)
完全外连接:左右表都不加限制。即结果为:左右表匹配的数据+左表没有匹配到的数据+右表没有匹配到的数据。(完全外连接就是在等值连接的基础上将左表和右表的未匹配数据都加上)


连接的语法:(通常外连接省略outer关键字)
left/right/full outer join ...on
left/right/full join ...on
(+)号的作用:+号可以理解为补充的意思,即哪个表有加号,这个表就是匹配表。加在右表的列上代表右表为补充,为左外连接。加在左表的列上代表左表为补充,为右外连接。
注意:完全外连接不支持(+)写法。


创建两种表,生出测试数据:


CREATE TABLE TQA (
id   number,
name  VARCHAR2(10)
);
CREATE TABLE TUB (
id   number,
name  VARCHAR2(10)
);


INSERT INTO TQA VALUES(1,'QA');
INSERT INTO TQA VALUES(2,'QB');
INSERT INTO TQA VALUES(3,'QC');
INSERT INTO TQA VALUES(4,'QD');
INSERT INTO TQA VALUES(5,'QE');


INSERT INTO TUB VALUES(1,'UA');
INSERT INTO TUB VALUES(1,'UB');
INSERT INTO TUB VALUES(2,'UC');
INSERT INTO TUB VALUES(1,'UD');
INSERT INTO TUB VALUES(7,'UE');


左外连接
select from TQA a left join TUB b on a.id=b.id;
select
from TQA a,TUB b where a.id=b.id(+);

右外连接
select from TQA a right join TUB b on a.id = b.id;
select
from TQA a,TUB b where a.id(+)=b.id;

完全外连接
select from TQA a full join TUB b on a.id=b.id;

等值连接(内连接也可省略关键字inner,直接写成join)
select
from TQA a,TUB b where a.id=b.id;
select * from TQA a join TUB b on a.id=b.id;~等值连接也可以这样写

注意:等值连接和完全外连接是有区别的。等值连接是只把满足条件的两个表的行相连,然后显示出来。完全外连接是把匹配查询条件的、左表没有匹配到的、右表没有匹配到的行都显示出来。


总结


SQL  连接(inner/outer join)包括以下:
内连接(两边的表都加限制)--[inner] join
左外连接(左边的表不加限制)--left [outer] join
右外连接(右边的表不加限制)--right [outer] join
全外连接(左右两表都不加限制)--full [outer] join


  在左外连接和右外连接时都会以主表为基础表,该表的内容会全部显示,然后加上主表和匹配表匹配的内容。 如果主表的数据在匹配表中没有记录,那么在相关联的结果集行中列显示为空值(null)。


内连接,可以使用"(+)",但是必须省略。即两张表均为"主表",都不是匹配表。
而对于外连接, 也可以使用“(+) ”来表示。


关于外连接使用(+)的一些注意事项:



  1. (+)操作符只能出现在where子句中,并且不能与outer join语法同时使用。


  2. 当使用(+)操作符执行外连接时,如果在where子句中包含有多个条件,则必须在所有条件中都包含(+)操作符。


  3. (+)操作符只适用于列,而不能用在表达式上。


  4. (+)操作符不能与or和in操作符一起使用。


  5. (+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。


本文由职坐标整理并发布,希望对同学们学习Oracle有所帮助,更多内容请关注职坐标数据库Oracle数据库频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 2 不喜欢 | 0
看完这篇文章有何感觉?已经有2人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程