SQL内连接、外连接以及(+)号用法
admin
2023-04-15 02:41:21
0

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(+);
SQL内连接、外连接以及(+)号用法
右外连接
select from TQA a right join TUB b on a.id = b.id;
select
from TQA a,TUB b where a.id(+)=b.id;
SQL内连接、外连接以及(+)号用法
完全外连接
select from TQA a full join TUB b on a.id=b.id;
SQL内连接、外连接以及(+)号用法
等值连接(内连接也可省略关键字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内连接、外连接以及(+)号用法

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

总结

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. (+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。

相关内容

热门资讯

【第一消息】“来趣广西麻将到底... 家人们!今天小编来为大家解答来趣广西麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里...
玩家最新攻略“星悦麻将怎么开挂... 玩家最新攻略“星悦麻将怎么开挂?”(必胜开挂神器)您好,星悦麻将这个游戏其实有挂的,确实是有挂的,需...
【第一消息】“福麻圈到底是不是... 您好:福麻圈这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏中...
今日重大消息“悠悠众娱怎么开挂... 您好:悠悠众娱这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
玩家攻略科普“四方棋牌可以开挂... 您好:四方棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
玩家最新攻略“科乐吉林麻将真的... 家人们!今天小编来为大家解答科乐吉林麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
玩家攻略科普“杭麻圈辅助器?”... 网上科普关于“杭麻圈有没有挂”话题很是火热,小编也是针对杭麻圈作*弊开挂的方法以及开挂对应的知识点,...
终于了解“游游棋牌辅助器?”(... 终于了解“游游棋牌辅助器?”(透视曝光猫腻)您好,游游棋牌这个游戏其实有挂的,确实是有挂的,需要了解...
玩家最新攻略“星悦麻将辅助器?... 您好:星悦麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
【第一财经】“牵手跑胡子辅助器... 有 亲,根据资深记者爆料牵手跑胡子是可以开挂的,确实有挂(咨询软件无需打...