零全零美(www.zzgwt.com)
          生活中的很多事情,并不像If...Else那么簡(jiǎn)單!
          posts - 96,comments - 52,trackbacks - 0

          無其他條件

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

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

          在主表加附加條件 

          1select * from n_fwy_a a ,n_fwy_b b where a.id=b.id(+and a.id >5 order by a.id;
          2select * from n_fwy_a a left join n_fwy_b b on a.id=b.id where a.id>5 order by a.id;
          3select * 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ù)

          在附表中加條件

           

          1select * from n_fwy_a a ,n_fwy_b b where a.id=b.id(+and b.id(+>5 order by a.id;
          2select * from n_fwy_a a left join n_fwy_b b on a.id=b.id where b.id >5 order by a.id;--no
          3select * 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操作 

          1select * 
          2from n_fwy_a a ,
          3(select * from n_fwy_b b where b.id in (2,8)) b
          4where a.id=b.id (+);
          5select * 
          6from 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é)果一致 
           

          1select * 
          2from (select * from n_fwy_a a where a.id in (2,9)) a ,
          3n_fwy_b b
          4where a.id=b.id (+);
          5select * 
          6from 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é)果.

          posted on 2008-04-17 23:59 零全零美 閱讀(2700) 評(píng)論(0)  編輯  收藏

          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 阳朔县| 岢岚县| 郑州市| 北票市| 湘潭县| 禹城市| 菏泽市| 饶阳县| 宜兴市| 津南区| 黎平县| 吕梁市| 潼南县| 武夷山市| 扎赉特旗| 湘西| 新泰市| 蓬莱市| 威信县| 大洼县| 化州市| 寿阳县| 海门市| 方正县| 茶陵县| 钦州市| 乌恰县| 景泰县| 岐山县| 肥东县| 吉安市| 广水市| 合江县| 瑞丽市| 工布江达县| 四子王旗| 宁海县| 葵青区| 澄江县| 奉新县| 乐清市|