<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-94  評論-56  文章-3  trackbacks-0
    索引是表的一個概念部分 , 用來提高檢索數據的效率, ORACLE 使用了一個復雜的自平衡 B-tree 結構 . 通常 , 通過索引查詢數據比全表掃描要快 . ORACLE 找出執行查詢和 Update 語句的最佳路徑時 , ORACLE 優化器將使用索引。
    大部分的性能問題其實都是索引應用的問題,Where子句、Order By、Group?By 都要用到索引。
    一般開發人員認為將索引建全了就可以下班回家了,實則還有頗多的思量和陷阱。


    索引列上不要使用IS NULL 或 IS NOT NULL
    ×?SELECT?Col?FROM?tbl?WHERE?col?IS?NULL

    索引列上不要使用函數
    ×?SELECT?Col?FROM?tbl?WHERE?substr(name , ? 1 , ? 3 )? = ?'ABC'
    ○?SELECT?Col?FROM?tbl?WHERE?name?LIKE?'ABC%'
    WHERE子句中,如果索引列是函數的一部分.優化器將不使用索引而使用全表掃描.

    索引列上不要使用NOT != <>
    ×?SELECT?Col?FROM?tbl?WHERE?col?! = ? 10
    ○?SELECT?Col?FROM?tbl?WHERE?col?>?
    10 ?OR?col?<? 10

    記住 , 索引只能告訴你什么存在于表中 , 而不能告訴你什么不存在于表中 . 要避免在索引列上使用NOT, NOT會產生在和在索引列上使用函數相同的影響. ORACLE”遇到”NOT,他就會停止使用索引轉而執行全表掃描。

    索引列上不要進行計算

    ×?SELECT?Col?FROM?tbl?WHERE?col?/? 10 ?>? 10
    ○?SELECT?Col?FROM?tbl?WHERE?col?>?
    10 ?*? 10
    這是最最普遍的失效陷阱,比如where trunc(order_date)=trunc(sysdate), i+2>4。索引失效的原因也簡單,索引是針對原值建的二叉樹,你將列值*3/4+2折騰一番后,原來的二叉樹當然就用不上了。




    ?


    posted on 2007-01-22 11:13 小言身寸 閱讀(2304) 評論(0)  編輯  收藏 所屬分類: 數據庫/SQL語言
    主站蜘蛛池模板: 四虎影视无码永久免费| 免费一区二区三区在线视频| 国产成人AV免费观看| 全部免费毛片在线| 美女羞羞视频免费网站| 国产免费观看a大片的网站| 日本系列1页亚洲系列| 热99re久久免费视精品频软件 | 免费黄色大片网站| 精品国产日韩久久亚洲| 在线观看成人免费视频| 在线观看亚洲精品专区| 亚洲AV无码成H人在线观看| 一级毛片免费播放试看60分钟| 亚洲国产aⅴ综合网| 一级做a爰片久久免费| 亚洲开心婷婷中文字幕| 免费h视频在线观看| 亚洲国产日产无码精品| 成人毛片18女人毛片免费96 | 卡一卡二卡三在线入口免费| 亚洲日韩亚洲另类激情文学| 国产精品免费综合一区视频| 全黄A免费一级毛片| 亚洲av无码一区二区三区乱子伦| 亚洲视频在线免费看| 亚洲精品无码专区在线| 精品国产香蕉伊思人在线在线亚洲一区二区| 成年女人A毛片免费视频| 精品日韩亚洲AV无码一区二区三区| 国产精品色拉拉免费看| 国产午夜亚洲精品不卡| 久久精品国产亚洲一区二区| 男女做羞羞的事视频免费观看无遮挡 | 99精品热线在线观看免费视频 | 亚洲一本大道无码av天堂| 日本免费高清视频| 亚洲人成电影网站免费| 亚洲色无码一区二区三区| 国产人在线成免费视频| 国产A∨免费精品视频|