亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 2914 | 回復: 2
打印 上一主題 下一主題

db2的sql中的內(nèi)外連接 [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2005-11-18 11:17 |只看該作者 |倒序瀏覽
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)連接,全有才有;左外連接,左有就有;右外連接,右有就有;全外連接,全都有.

論壇徽章:
0
2 [報告]
發(fā)表于 2005-11-19 10:45 |只看該作者
Well Done!

論壇徽章:
0
3 [報告]
發(fā)表于 2005-11-21 15:23 |只看該作者
多謝鼓勵!
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP