天天看點

Oracle左連接配接,右連接配接

資料表的連接配接有: 

1、内連接配接(自然連接配接): 隻有兩個表都相比對的行才能在結果集中出現 

2、外連接配接: 包括 

     (1)左外連接配接(左邊的表不加限制),右表補null 

     (2)右外連接配接(右邊的表不加限制) ,左表補null

     (3)全外連接配接(左右兩表都不加限制) ,左右兩表空缺行補null

3、自連接配接(連接配接發生在一張基表内) 

 查詢結果如下:

STUDENTNO        STUDENTNAM           CLASSNAME

----------            ----------                 --------------------

            1                aa                         一年級一班

            2                bb                         一年級二班

           null              null                        一年級三班

以上語句是右連接配接:

即"(+)"所在位置的另一側為連接配接的方向,右連接配接說明等号右側的所有記錄均會被顯示,無論其在左側是否得到比對。也就是說上例中,無論會不會出現某個班級沒有一個學生的情況,這個班級的名字都會在查詢結構中出現。即"(+)"表示所在的列的值,如果沒有比對的值,則加入null值,并顯示出來。

//通常将全量集合與部分集合連接配接時,在部分集合的列後面帶上(+),以達到沒有比對時,也要顯示出一個null的效果。

反之: 

查詢結果:

STUDENTNO                 STUDENTNAME              CLASSNAME

----------                     ----------                   ------------------------------

            1                             aa                        一年級一班

            2                             bb                       一年級二班

            3                             aa                         null

則是左連接配接,無論這個學生有沒有一個能在一個班級中得到比對的班級号,這個學生的記錄都會被顯示。

這個則是通常用到的内連接配接,顯示兩表都符合條件的記錄 

總之, 

左連接配接顯示左邊全部的和右邊與左邊相同的 

右連接配接顯示右邊全部的和左邊與右邊相同的 

内連接配接是隻顯示滿足條件的!

例子:

表示process_card_procedure表和group_task表的左連接配接。查詢結果部分如下:

Oracle左連接配接,右連接配接

上表中的state字段是在group_task表中,連接配接過程中後面三條記錄沒有state字段,顯示為null,如果不左連接配接,

查詢結果如下:

Oracle左連接配接,右連接配接

本文轉自xwdreamer部落格園部落格,原文連結:http://www.cnblogs.com/xwdreamer/archive/2011/09/27/2296960.html,如需轉載請自行聯系原作者