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 閱讀(956) 評論(1)  編輯  收藏 所屬分類: 牧羊陣法

          Feedback

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

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


          My Links

          Blog Stats

          News

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          新聞檔案

          相冊

          常去網站

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 湟源县| 九龙县| 桑植县| 县级市| 饶阳县| 易门县| 白朗县| 新营市| 招远市| 泰州市| 乳山市| 常德市| 祁门县| 兴化市| 石狮市| 红河县| 丹江口市| 全州县| 本溪市| 澄城县| 安新县| 靖边县| 和顺县| 修武县| 昌吉市| 连平县| 临汾市| 绥中县| 宜宾县| 宁波市| 准格尔旗| 竹山县| 大邑县| 西贡区| 吉水县| 修武县| 竹溪县| 肥西县| 汤原县| 来安县| 宜兰市|