Oracle左連接(+在等號右邊),右連接(+在等號左邊)

數據表的連接有:
1、內連接(自然連接): 只有兩個表相匹配的行才能在結果集中出現
2、外連接: 包括 
     (1)左外連接(左邊的表不加限制)
     (2)右外連接(右邊的表不加限制)
     (3)全外連接(左右兩表都不加限制)
3、自連接(連接發生在一張基表內)
select a.studentno, a.studentname, b.classname
      from students a, classes b
      where a.classid(+) = b.classid;
STUDENTNO STUDENTNAM CLASSNAME
---------- ---------- ------------------------------
            1 aa          一年級一班
            2 bb          一年級二班
                             一年級三班
以上語句是右連接:
即"(+)"所在位置的另一側爲連接的方向,右連接說明等號右側的所有記錄均會被顯示,無論其在左側是否得到匹配。也就是說上例中,無論會不會出現某個班級沒有一個學生的情況,這個班級的名字都會在查詢結構中出現。

即"(+)"表示所在的列的值,如果沒有匹配的值,則加入null值,並顯示出來。.

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


反之:
select a.studentno, a.studentname, b.classname
       from students a, classes b
      where a.classid = b.classid(+);

STUDENTNO STUDENTNAM CLASSNAME
---------- ---------- ------------------------------
            1 aa          一年級一班
            2 bb          一年級二班
            3 aa

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

select a.studentno, a.studentname, b.classname
       from students a, classes b
      where a.classid = b.classid;

這個則是通常用到的內連接,顯示兩表都符合條件的記錄
總之,
左連接顯示左邊全部的和右邊與左邊相同的
右連接顯示右邊全部的和左邊與右邊相同的
內連接是隻顯示滿足條件的!

發佈了51 篇原創文章 · 獲贊 6 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章