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)

          隨筆分類

          隨筆檔案

          新聞檔案

          相冊

          常去網站

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 嘉善县| 清流县| 泗洪县| 庄浪县| 吉首市| 望江县| 忻城县| 连南| 鄢陵县| 沐川县| 海盐县| 鹿邑县| 原阳县| 保靖县| 兴山县| 佛山市| 焦作市| 松原市| 潜江市| 金山区| 景东| 潮安县| 芜湖市| 瓦房店市| 射阳县| 容城县| 望谟县| 葫芦岛市| 宽甸| 鄄城县| 云林县| 张家港市| 曲水县| 繁昌县| 巴东县| 定边县| 曲沃县| 涿州市| 南皮县| 天镇县| 瑞金市|