国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > 綜合 > 正文

教你快速掌握“外連接”的兩種標(biāo)準(zhǔn)寫法

2024-07-21 02:42:06
字體:
供稿:網(wǎng)友
在實(shí)際的工作和學(xué)習(xí)中,許多人也許對(duì)外關(guān)聯(lián)比較模糊,下面我們一起來看下面的示例:

無其他條件

select * from n_fwy_a a left join n_fwy_b b on a.id=b.id order by a.id;select * from n_fwy_a a ,n_fwy_b b where a.id=b.id(+) order by a.id;

這兩重寫法的查詢的結(jié)果一致

在主表加附加條件

select * from n_fwy_a a ,n_fwy_b b where a.id=b.id(+) and a.id >5 order by a.id;select * from n_fwy_a a left join n_fwy_b b on a.id=b.id where a.id>5 order by a.id;select * from n_fwy_a a left join n_fwy_b b on a.id=b.id and a.id>5 order by a.id;--no

這三種寫法的前兩種查詢結(jié)果一致,用第2種sql查詢得的結(jié)果發(fā)現(xiàn)出現(xiàn)了n_fwy_a的全集數(shù)據(jù)

在附表中加條件

select * from n_fwy_a a ,n_fwy_b b where a.id=b.id(+) and b.id(+) >5 order by a.id;select * from n_fwy_a a left join n_fwy_b b on a.id=b.id where b.id >5 order by a.id;--noselect * from n_fwy_a a left join n_fwy_b b on a.id=b.id and b.id >5 order by a.id;

此三種寫法的前1,3種查詢結(jié)果一致,用第2種sql查詢得的結(jié)果發(fā)現(xiàn)僅僅出現(xiàn)了b.id >5的數(shù)據(jù)集,而其他兩種結(jié)果集合是a的全集

--對(duì)于in 和 or 操作

在老風(fēng)格(+)的外關(guān)聯(lián)操作中,where 條件中是不允許附表引用in和or操作的。

--對(duì)于in操作

select * from n_fwy_a a ,(select * from n_fwy_b b where b.id in (2,8)) bwhere a.id=b.id (+);select * from n_fwy_a a left join n_fwy_b b on a.id=b.id and b.id in (2,8);

對(duì)于在附表中引用in和or操作,兩種寫法所得的結(jié)果一致

select * from (select * from n_fwy_a a where a.id in (2,9)) a ,n_fwy_b bwhere a.id=b.id (+);select * from n_fwy_a a left join n_fwy_b b on a.id=b.id and a.id in (2,9);

對(duì)于在主表中引用in和or操作,兩種寫法所得的結(jié)果就不一致了,和好理解第一種寫法的SQL把主表的數(shù)據(jù)集變小了,第二種寫法的sql的數(shù)據(jù)集還是主表的全集

--對(duì)于OR操作與in的一致

總結(jié):

相對(duì)于ANSI風(fēng)格的外關(guān)聯(lián),其on后的條件是關(guān)聯(lián)前的篩選數(shù)據(jù)條件,但是無論加什么條件,它的結(jié)果集大小與主表的數(shù)據(jù)集一樣大,對(duì)于其where后的條件是關(guān)聯(lián)之后的條件。

對(duì)于(+)風(fēng)格的外關(guān)聯(lián),where后的條件是關(guān)聯(lián)后的篩選數(shù)據(jù)的條件。針對(duì)附表不能使用in和or操作,若要使用應(yīng)該在關(guān)聯(lián)之前使用,以縮小數(shù)據(jù)集合(即在from 中使用表查詢),否則的話,起不到外關(guān)聯(lián)的作用,結(jié)果集為內(nèi)連接的結(jié)果。


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 剑川县| 尼木县| 渭南市| 临城县| 临清市| 和龙市| 通榆县| 肥城市| 大安市| 闵行区| 崇州市| 荣昌县| 弥勒县| 会理县| 河津市| 泾阳县| 湄潭县| 吉首市| 广水市| 靖江市| 府谷县| 治县。| 衡水市| 望谟县| 九龙城区| 玉林市| 临邑县| 仁化县| 资兴市| 江安县| 泌阳县| 东安县| 灌云县| 呼图壁县| 汕尾市| 阜新| 舒兰市| 聊城市| 莱芜市| 绥棱县| 聊城市|