SQL内连接,外连接以及(+)号用法

  

SQL提供了多种类型的连接方式,它们之间的区别在于:从相互交叠的不同数据集合中选择用于连接的行时所采用的方法不同。

  

a内连接

  

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

  

b外连接

  

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

  

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

  

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

  

创建表TQA (
id号,
名称VARCHAR2 (10)
);
CREATE TABLE浴缸(
id号,
名称VARCHAR2 (10)
);

  

插入TQA值(QA);
插入TQA值(2,' QB ');
插入TQA值(3,“质量控制”);
插入TQA值(4,QD);
插入TQA值(5“量化宽松政策”);

  

插入桶值(UA);
插入桶值(1,乌兰巴托);
插入桶值(2,“加州大学”);
插入桶值(1,UD);
插入桶值(7,“问题”);

  

左外连接
从TQA选择左加入浴缸b alt=" SQL内连接,外连接以及(+)号用法”>
右外连接
从TQA正确选择加入浴缸b alt=" SQL内连接,外连接以及(+)号用法”>
完全外连接
从TQA全面加入浴缸选择 b alt=" SQL内连接,外连接以及(+)号用法”>
等值连接(内连接也可省略关键字内,直接写成联接)
从TQA选择
a, b浴缸,a.id=b.id;
select * from TQA加入浴缸b alt=" SQL内连接,外连接以及(+)号用法">

  

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

  

总结

  

SQL连接(内部/外部连接)包括以下:
内连接(两边的表都加限制)——(内部)加入
左外连接(左边的表不加限制),左(外)加入
右外连接(右边的表不加限制),对(外)加入
全外连接(左右两表都不加限制),完整的(外)加入

  

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

  

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

  

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

  
      <李>(+)操作符只能出现在,子句中,并且不能与外连接语法同时使用。   <李>当使用(+)操作符执行外连接时,如果在哪里子句中包含有多个条件,则必须在所有条件中都包含(+)操作符。   <李>(+)操作符只适用于列,而不能用在表达式上。   <李>(+)操作符不能与或和操作符一起使用。   <李>(+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。   

SQL内连接,外连接以及(+)号用法