oracle左外连接、右外连接、完全外连接以及(+)号用法

转:https://blog.csdn.net/fly_zxy/article/details/53954377

准备工作

oracle连接分为:
  1. 左外连接:左表不加限制,保留左表的数据,匹配右表,右表没有匹配到的行中的列显示为null。
  2. 右外连接:右表不加限制,保留右表的数据。匹配左表,左表没有匹配到的行中列显示为null。
  3. 完全外连接:左右表都不加限制。即右外连接的结果为:左右表匹配的数据+左表没有匹配到的数据+右表没有匹配到的数据。

连接的语法:

  1. left/right/full outer join …on
  2. left/right/full join …on
(+)号的作用:+号可以理解为补充的意思,加在那个表的列上就代表这个表的列为补充。加在右表的列上代表右表为补充,为左连接。加在左表的列上代表左表为补充,为右连接。注意:完全外连接中不能使用+号。


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

     
     
  1. CREATE TABLE t_A (
  2. id number,
  3. name VARCHAR2( 10)
  4. );
  5. CREATE TABLE t_B (
  6. id number,
  7. name VARCHAR2( 10)
  8. );
  9. INSERT INTO t_A VALUES( 1, ‘A’);
  10. INSERT INTO t_A VALUES( 2, ‘B’);
  11. INSERT INTO t_A VALUES( 3, ‘C’);
  12. INSERT INTO t_A VALUES( 4, ‘D’);
  13. INSERT INTO t_A VALUES( 5, ‘E’);
  14. INSERT INTO t_B VALUES( 1, ‘AA’);
  15. INSERT INTO t_B VALUES( 1, ‘BB’);
  16. INSERT INTO t_B VALUES( 2, ‘CC’);
  17. INSERT INTO t_B VALUES( 1, ‘DD’);
  18. INSERT INTO t_B VALUES( 7, ‘GG’);



左外连接


     
     
  1. select * from t_a a left join t_b b on a.id=b.id;
  2. select * from t_a a,t_b b where a.id=b.id(+);

右外连接


      
      
  1. select * from t_a a right join t_b b on a.id = b.id;
  2. select * from t_a a,t_b b where a.id(+)=b.id;


完全外连接

select * from t_a a full join t_b b on a.id=b.id;
      
      


等值连接(我们在看看等值连接的结果)


       
       
  1. select * from t_a a,t_b b where a.id=b.id;
  2. select * from t_a a join t_b b on a.id=b.id; –等值连接也可以这样写

注意:以前理解等值连接和完全外连接是一回事,现在看来是我理解错了。等值连接是只把满足条件的两个表的行相连,然后显示出来。完全外连接是把匹配查询条件的行、左表没有匹配到的、右表没有匹配到的都显示出来。



        </div>
            </div>

准备工作

oracle连接分为:
  1. 左外连接:左表不加限制,保留左表的数据,匹配右表,右表没有匹配到的行中的列显示为null。
  2. 右外连接:右表不加限制,保留右表的数据。匹配左表,左表没有匹配到的行中列显示为null。
  3. 完全外连接:左右表都不加限制。即右外连接的结果为:左右表匹配的数据+左表没有匹配到的数据+右表没有匹配到的数据。

连接的语法:

  1. left/right/full outer join …on
  2. left/right/full join …on
(+)号的作用:+号可以理解为补充的意思,加在那个表的列上就代表这个表的列为补充。加在右表的列上代表右表为补充,为左连接。加在左表的列上代表左表为补充,为右连接。注意:完全外连接中不能使用+号。


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

   
   
  1. CREATE TABLE t_A (
  2. id number,
  3. name VARCHAR2( 10)
  4. );
  5. CREATE TABLE t_B (
  6. id number,
  7. name VARCHAR2( 10)
  8. );
  9. INSERT INTO t_A VALUES( 1, ‘A’);
  10. INSERT INTO t_A VALUES( 2, ‘B’);
  11. INSERT INTO t_A VALUES( 3, ‘C’);
  12. INSERT INTO t_A VALUES( 4, ‘D’);
  13. INSERT INTO t_A VALUES( 5, ‘E’);
  14. INSERT INTO t_B VALUES( 1, ‘AA’);
  15. INSERT INTO t_B VALUES( 1, ‘BB’);
  16. INSERT INTO t_B VALUES( 2, ‘CC’);
  17. INSERT INTO t_B VALUES( 1, ‘DD’);
  18. INSERT INTO t_B VALUES( 7, ‘GG’);



左外连接


   
   
  1. select * from t_a a left join t_b b on a.id=b.id;
  2. select * from t_a a,t_b b where a.id=b.id(+);

右外连接


    
    
  1. select * from t_a a right join t_b b on a.id = b.id;
  2. select * from t_a a,t_b b where a.id(+)=b.id;


完全外连接

select * from t_a a full join t_b b on a.id=b.id;
    
    


等值连接(我们在看看等值连接的结果)


     
     
  1. select * from t_a a,t_b b where a.id=b.id;
  2. select * from t_a a join t_b b on a.id=b.id; –等值连接也可以这样写

注意:以前理解等值连接和完全外连接是一回事,现在看来是我理解错了。等值连接是只把满足条件的两个表的行相连,然后显示出来。完全外连接是把匹配查询条件的行、左表没有匹配到的、右表没有匹配到的都显示出来。



        </div>
            </div>

猜你喜欢

转载自blog.csdn.net/lvjingwn/article/details/80937595