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

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

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

    posts - 188,comments - 176,trackbacks - 0

    Like SQL語句的優化的一個小測試

    1.盡量不要使用 like '%..%'

    2.對于 like '..%..' (不以 % 開頭),Oracle可以應用 colunm上的index

    3.對于 like '%...' 的 (不以 % 結尾),可以利用reverse + function index 的形式,變化成 like '..%'

    具體的測試流程: (測試工具:PLSQL Developer)


    [1] '建測試表和Index,注意,重點在于帶reverse的function index。同時,一定要使用CBO才行。

    已連接到 Oracle Database 10g Enterprise Edition Release 10.2.0.1.0
    已連接為 zxdbm_ismp

    SQL> select reverse('123') from dual;

    REVERSE('123')
    --------------
    321

    SQL> create table test_like as select object_id,object_name from dba_objects;

    Table created.

    SQL> create index test_like_name on test_like(object_name);

    Index created.

    SQL> create index test_like_name_reverse on test_like(reverse(object_name));  --建反向索引

    Index created.

    SQL> analyze table test_like compute statistics for table for all indexes;

    Table analyzed.

    SQL> set autotrace trace exp

     

    [2] '常量開頭的like , 會利用index ,沒問題…… '

    SQL> select * from test_like where object_name like 'AS%';

    Execution Plan

    ----------------------------------------------------------

    0 SELECT STATEMENT Optimizer=CHOOSE (Cost=2 Card=655 Bytes=15720)

    1 0 TABLE ACCESS (BY INDEX ROWID) OF 'TEST_LIKE' (Cost=2 Card=655Bytes=15720)

    2 1 INDEX (RANGE SCAN) OF 'TEST_LIKE__NAME' (NON-UNIQUE) (Cost=2 Card=118)

     

    [3] '開頭和結尾都是 % ,對不起,很難優化'

    SQL> select * from test_like where object_name like '%%';


    Execution Plan

    ----------------------------------------------------------

    0 SELECT STATEMENT Optimizer=CHOOSE (Cost=6 Card=655 Bytes=15720)

    1 0 TABLE ACCESS (FULL) OF 'TEST_LIKE' (Cost=6 Card=655 ytes=15720)

     

    [4] '以常量結束,直接寫的時候是不能應用index的'

    SQL> select * from test_like where object_name like '%S';

    Execution Plan

    ----------------------------------------------------------

    0 SELECT STATEMENT Optimizer=CHOOSE (Cost=6 Card=655 Bytes=15720)

    1 0 TABLE ACCESS (FULL) OF 'TEST_LIKE' (Cost=6 Card=655 Bytes=15720)

     

    [5] '以常量結束的,加個reverse 函數,又可以用上index了'(需要反向索引的支持)

    SQL> select * from test_like where reverse(object_name)like reverse('%AS');

    Execution Plan

    ----------------------------------------------------------

    0 SELECT STATEMENT Optimizer=CHOOSE (Cost=2 Card=655 Bytes=15720)

    1 0 TABLE ACCESS (BY INDEX ROWID) OF 'TEST_LIKE' (Cost=2 Card=655 Bytes=15720)

    2 1 INDEX (RANGE SCAN) OF 'TEST_LIKE__NAME_REVERSE' (NON-UNIQUE) (Cost=2 Card=118)



    轉:http://rollingpig.itpub.net/category/81/30081
    posted on 2008-01-23 15:58 cheng 閱讀(4303) 評論(2)  編輯  收藏 所屬分類: Oracle

    FeedBack:
    # re: Like SQL語句的優化[未登錄]
    2008-04-21 10:33 | paul
    [5] '以常量結束的,加個reverse 函數,又可以用上index了'
    我試了下怎么不管用啊  回復  更多評論
      
    # re: Like SQL語句的優化
    2008-04-21 21:00 | cheng
    @paul
    select * from test_like where reverse(object_name)like reverse('%AS');
    需要建立對object_name的反向索引才行的。  回復  更多評論
      
    主站蜘蛛池模板: 亚洲中文无码亚洲人成影院| 国产精品免费观看久久| 风间由美在线亚洲一区| 亚洲一本综合久久| 国产精品V亚洲精品V日韩精品| 美女视频黄的全免费视频| 国内精品免费在线观看| 老妇激情毛片免费| 亚洲精品无码久久久久牙蜜区| 亚洲视频在线一区| 亚洲精品V欧洲精品V日韩精品| 免费人妻无码不卡中文字幕18禁| 精品久久久久成人码免费动漫 | 9久9久女女免费精品视频在线观看| 亚洲免费一区二区| 国产AV无码专区亚洲AV麻豆丫 | 亚洲免费在线视频| 中文精品人人永久免费| 日韩精品无码免费视频| 久久亚洲AV成人无码国产电影| 亚洲中文无码永久免费| ass亚洲**毛茸茸pics| 亚洲成aⅴ人片在线影院八| 亚洲AV成人一区二区三区AV| 亚洲精品美女久久久久99| 亚洲综合无码精品一区二区三区| 国产一级特黄高清免费大片| 日本高清免费不卡在线| 黑人粗长大战亚洲女2021国产精品成人免费视频 | 成人特级毛片69免费观看| 色偷偷噜噜噜亚洲男人| 亚洲精品天堂无码中文字幕| 亚洲看片无码在线视频| wwwxxx亚洲| 亚洲色偷偷综合亚洲AV伊人蜜桃 | 美女视频黄免费亚洲| 成人性生交大片免费看无遮挡 | 亚洲综合激情六月婷婷在线观看| 亚洲激情视频在线观看| 亚洲天堂久久精品| 亚洲1区1区3区4区产品乱码芒果|