欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

簡單介紹join,outer-join,semi-join,anti-join

系統 2031 0

表連接的方式如join,semi-join,outer-join,anti-join;
表連接的實現方式如nested loop,merge,hash.
本文簡單的介紹表連接的方式join,semi-join,outer-join,anti-join和適用情景。

假設2個數據源(row source).
Emp(id pk,ename,deptno) Dept(deptno pk,dname)

如下是join
select ename,dname from emp,dept where emp.deptno=dname.deptno;
2個數據源鍵值一一比較,返回相互匹配的記錄集
for example: nested loop join
for x in ( select * from emp )
loop
for y in ( select * from dept)
loop
if ( x.deptno == y.deptno )
OutPut_Record(x.ename,y.dname)
End if
end loop
end loop

outer-join
select ename,dname from emp,dept where emp.deptno= dept.deptno(+);
select ename,dname from emp,dept where emp.deptno(+)=dept.deptno;
2個數據源鍵值一一比較,返回相互匹配的;但如果在另外一個row source沒有找到匹配的也返回記錄
for example: nested loop outer-join
for x in ( select * from emp )
loop
find_flag=false;
for y in ( select * from dept)
loop
if ( x.deptno == y.deptno )
OutPut_Record(x.ename,y.dname)
Find_flag=true
End if
end loop
if ( find_flag == false )
OutPut_Record(x.ename,null)
End if
end loop
semi-join
select dname from dept where exists( select null from emp where emp.deptno=dept.deptno)
多在子查詢exists中使用,對外部row source的每個鍵值,查找到內部row source匹配的第一個鍵值后就返回,如果找到就不用再查找內部row source其他的鍵值了。
for example: nested loop semi-join


for x in ( select * from dept )
loop
for y in ( select * from emp)
loop
if ( x.deptno == y.deptno )
OutPut_Record(x.dname)
Break;
End if
end loop
end loop

anti-join
select ename,deptno from emp,dept where emp.deptno!=dept.deptno
多用于!= not in 等查詢;如果找到滿足條件(!= not in)的不返回,不滿足條件(!= not in)的返回。和join相反。
 for example: nested loop anti-join
for x in ( select * from emp )
loop
for y in ( select * from dept)
loop
if ( x.deptno != y.deptno )
OutPut_Record(x.dname,y.deptno)
End if
end loop
end loop

簡單介紹join,outer-join,semi-join,anti-join的區別


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久女人被添全过程A片 | 天天影视免费在线观看入口 | 一级啪啪片 | 亚洲一区二区三区四区精品 | 91久久亚洲国产成人精品性色 | 波多野结衣xfplay在线观看 | 99精品在线观看 | 中文字幕无线码一区二区三区 | 欧美日韩在线视频播放 | 国产拍视频 | 国产亚洲精品日韩香蕉网 | 一级毛片私人影院老司机 | 午夜精品久久久久久久90蜜桃 | 久久福利青草狠狠午夜 | 四虎精品8848ys一区二区 | 日韩在线观看视频一区 | 伦理午夜电影免费观看 | 欧洲精品在线视频 | 亚洲国产日韩欧美高清片a 高清视频在线播放 | 久久国产成人福利播放 | 免费一区二区三区 | 91精品视频在线播放 | 国产一区二区精品久久91 | 魔法骑士在线观看免费完整版高清 | 成人在线观看国产 | 青草国产超碰人人添人人碱 | 亚洲天堂久久精品成人 | 九九色影院 | 欧美一级毛片欧美毛片视频 | 成人精品视频在线观看 | 九色在线视频 | xxnxx中国18 | xxx视频| 欧美大片在线免费观看 | 亚洲国产精品久久久久666 | 亚洲国产精品第一区二区三区 | 国产精品久久久久免费 | 一级免费黄色免费片 | 国产碰碰 | 午夜网站入口 | 一区二区三区日韩精品 |