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

          Feedback

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

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


          My Links

          Blog Stats

          News

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          新聞檔案

          相冊

          常去網站

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 岗巴县| 牙克石市| 澄江县| 石林| 于田县| 两当县| 延吉市| 修水县| 瑞金市| 新源县| 荔波县| 泰宁县| 子洲县| 康平县| 尼木县| 凤山县| 乾安县| 宾阳县| 肇东市| 随州市| 青岛市| 九寨沟县| 德州市| 乐昌市| 台东县| 沙河市| 京山县| 德庆县| 开阳县| 甘谷县| 杂多县| 陇西县| 岑巩县| 泾川县| 皋兰县| 高密市| 景德镇市| 丰镇市| 巴彦淖尔市| 都兰县| 治县。|