- 論壇徽章:
- 0
|
db2的sql中的內(nèi)外連接
有表t1,t2
t1:
C1 C2 C3
-- ---------- --
1 rick B0
2 smith C0
3 john E0
3 條記錄已選擇。
t2:
C1 C2
-- ----------
A0 sale DEPT
B0 prod DEPT
C0 cout DEPT
D0 mage DEPT
4 條記錄已選擇。
1.db2的內(nèi)連接
下面是內(nèi)連接,內(nèi)連接和普通的where子句,輸出相同,即在兩表共有的行才會輸出,即也可以用:select * from t1,t2 where t1.c3=t2.c1
內(nèi)連接沒有左右之分.
db2 => select * from t1 inner join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
2 條記錄已選擇。
2.db2的外連接:外連接分左外連接右外連接,下面我們看看他們的區(qū)別:
db2 => select * from t1 left outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
3 john E0 - -
3 條記錄已選擇。
左連接保留前面表的所有記錄,后表中沒有的補null.
db2 => select * from t1 right outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
- - - A0 sale DEPT
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
- - - D0 mage DEPT
4 條記錄已選擇。
左連接保留后表的所有記錄,前表中沒有的補null.
我們可以把右連接,的表的順序顛倒一下,并寫成左外連接,其結(jié)果應該是一樣的.
在DB2的內(nèi)部機制中,會把右外連接重寫成左外連接.故我們在寫sql語句時盡量使用左外連接.
3.全外連接.
db2 => select * from t1 full outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
- - - A0 sale DEPT
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
- - - D0 mage DEPT
3 john E0 - -
5 條記錄已選擇。
全外連接會輸出兩表的所有的數(shù)據(jù),包括內(nèi)連接和左外連接和右外連接的行.
4.與sybase的區(qū)別: sybase的sql語句相應的連接有:
select * from t1,t2 where t1.c3=t2.c1 相當于內(nèi)連接
select * from t1,t2 where t1.c3 *= t2.c1 相當于左外連接
select * from t1,t2 where t1.c3 =* t2.c1 相當于右外連接
總結(jié):
內(nèi)連接,全有才有;左外連接,左有就有;右外連接,右有就有;全外連接,全都有. |
|