Dust Of Dream

          知識真的是一個圓么?

          Oracle SQL培訓筆記[開發人員][三]

          四 索引與分頁--怎么樣SQL運行的更快

          1. 正確的使用索引
            Where條件落在索引上
            不要在where的=前使用函數,否則無法使用索引
            Is Null可能無法使用索引
            不正確的隱式轉換可能不能使用索引
            如果能在索引獲得數據,就不要回表
            如果是復合索引,注意第2個字段以后,可能使用不到索引
          2. 正確的使用hint
            如果有別名,一定要有別名
            格式如/*+ index(t index_name) */
          3. 無需回表查詢的分頁寫法
            存在以下表T1(A,B,C,D) T1上有索引字段(B,C) .如果只是查B,C兩個字段則:
            select *
              
            from (select tt.b, tt.c, rownum as rn
                      
            from (select t.b, t.c from t1 t where c = 2 order by t.c) tt
                     
            where rownum < 3)
             
            where rn > 1
          4. 需回表查詢的分頁寫法
            select /*+ ordered use_nl(t,t1) */ 
                  
            * 
                   
            from (select rid from (
                      
            select rownum rn,rid from (
                        
            select rowid rid from t1
                         
            where c=2 
                         
            order by c desc
                      
            where rownum <= 50
                   
            where rn >=1) t,
                   t1
            where t.rid=t1.rowid;


          posted on 2007-10-01 12:48 Anemone 閱讀(961) 評論(1)  編輯  收藏 所屬分類: 牧羊陣法

          Feedback

          # re: Oracle SQL培訓筆記[開發人員][三] 2008-05-29 10:11 Anemone

          對于分頁寫法只要寫了hit(/*+ ordered use_nl(t,t1) */ )就不需要增加外排序了,它本身返回的結果就是排序的.  回復  更多評論   


          My Links

          Blog Stats

          News

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          新聞檔案

          相冊

          常去網站

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 清水河县| 桂东县| 崇礼县| 廊坊市| 隆安县| 浮梁县| 文化| 吕梁市| 建德市| 昆山市| 金乡县| 台山市| 荆州市| 海淀区| 迭部县| 灵台县| 子洲县| 喜德县| 长岛县| 荆门市| 辽宁省| 喀什市| 福贡县| 上饶市| 麻阳| 武宁县| 马公市| 平果县| 景谷| 西平县| 静乐县| 东阿县| 天峻县| 三门县| 南召县| 和田县| 格尔木市| 北辰区| 涿鹿县| 斗六市| 塘沽区|