天天看點

内連接配接與外連接配接

資料表的連接配接有:

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 周虎 一年級一班

2 周林 一年級二班

一年級三班

以上語句是右連接配接:

即"(+)"所在位置的另一側為連接配接的方向,右連接配接說明等号右側的所有

記錄均會被顯示,無論其在左側是否得到比對。也就是說上例中,無

論會不會出現某個班級沒有一個學生的情況,這個班級的名字都會在

查詢結構中出現。

反之:

select

a.studentno, a.studentname, b.classname

where

a.classid = b.classid(+);

STUDENTNO STUDENTNAM CLASSNAME

----------

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

3

鐘林達

則是左連接配接,無論這個學生有沒有一個能在一個班級中得到比對的部門号,

這個學生的記錄都會被顯示。

a.classid = b.classid;

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

總之,

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

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

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

繼續閱讀