小菜毛毛技術(shù)分享

          與大家共同成長

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            164 Posts :: 141 Stories :: 94 Comments :: 0 Trackbacks

          數(shù)據(jù)表的連接有:
          1、內(nèi)連接(自然連接): 只有兩個表相匹配的行才能在結(jié)果集中出現(xiàn)
          2、外連接: 包括
          (1)左外連接(左邊的表不加限制)
          (2)右外連接(右邊的表不加限制)
          (3)全外連接(左右兩表都不加限制)
          3、自連接(連接發(fā)生在一張基表內(nèi))
          select a.studentno, a.studentname, b.classname
                from students a, classes b
                where a.classid(+) = b.classid;
          (另外一種寫法:
          select a.studentno,a.studentname,b.classname
                  from students right join class on students.classid=class.classid

          STUDENTNO STUDENTNAM CLASSNAME
          ---------- ---------- ------------------------------
                      1 周虎          一年級一班
                      2 周林          一年級二班
                                       一年級三班
          以上語句是右連接:
          即"(+)"所在位置的另一側(cè)為連接的方向,右連接說明等號右側(cè)的所有
          記錄均會被顯示,無論其在左側(cè)是否得到匹配。也就是說上例中,無
          論會不會出現(xiàn)某個班級沒有一個學(xué)生的情況,這個班級的名字都會在
          查詢結(jié)構(gòu)中出現(xiàn)。
          即是右連接是以右邊這個表為基準(zhǔn),左表不足的地方用NULL填充


          反之:
          select a.studentno, a.studentname, b.classname
                 from students a, classes b
                where a.classid = b.classid(+);

          (另外一種寫法:
          select a.studentno,a.studentname,b.classname
                  from students left join class on students.classid=class.classid


          STUDENTNO STUDENTNAM CLASSNAME
          ---------- ---------- ------------------------------
                      1 周虎          一年級一班
                      2 周林          一年級二班
                      3 鐘林達(dá)

          則是左連接,無論這個學(xué)生有沒有一個能在一個班級中得到匹配的部門號,
          這個學(xué)生的記錄都會被顯示。

          即是左連接是以左邊這個表為基準(zhǔn),右表表不足的地方用NULL填充

          select a.studentno, a.studentname, b.classname
                 from students a, classes b
                where a.classid = b.classid;
          (另外一種寫法:
          select a.studentno,a.studentname,b.classname
                  from students inner join class on students.classid=class.classid

          這個則是通常用到的內(nèi)連接,顯示兩表都符合條件的記錄

          總之,

          左連接顯示左邊全部的和右邊與左邊相同的
          右連接顯示右邊全部的和左邊與右邊相同的
          內(nèi)連接是只顯示滿足條件的!

           

          順便問下:有誰知道oracle左連接的兩種寫法的差異?

          有兩個表T1和T2,兩個表除了主鍵索引外均無其他索引,這兩個表由T1.F1(主鍵),T2.F2(主鍵)進(jìn)行左連接,SQL語句有兩種寫法:
          1. SELECT * FROM T1,T2 WHERE T1.F1=T2.F2(+)
          2. SELECT * FROM T1 LEFT JOIN T2 ON T1.F1=T2.F2

          當(dāng)查看1的執(zhí)行計劃時發(fā)現(xiàn)T1為全表掃描,T2為索引掃描。
          當(dāng)查看2的執(zhí)行計劃時發(fā)現(xiàn)兩個表均為全表掃描。
          posted on 2009-07-21 22:05 小菜毛毛 閱讀(4003) 評論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫
          主站蜘蛛池模板: 三亚市| 湘阴县| 池州市| 隆回县| 烟台市| 盐山县| 成都市| 阳曲县| 怀来县| 宜城市| 台江县| 磴口县| 沁阳市| 手游| 鄱阳县| 嘉义县| 卢湾区| 桐城市| 宝山区| 乐清市| 农安县| 景宁| 图片| 曲靖市| 秭归县| 资溪县| 乐亭县| 毕节市| 桦川县| 阳城县| 锦屏县| 永嘉县| 壤塘县| 杭州市| 石阡县| 迁安市| 永修县| 甘德县| 壶关县| 福建省| 洱源县|