posts - 119, comments - 62, trackbacks - 0, articles - 0

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

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

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

           

          建測試表和Index。

          注意:重點(diǎn)在于帶reverse的function index。同時,一定要使用CBO才行......

           

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

          REVERSE('123')

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

          321

          1 row selected.

           

          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 autot trace

           

          --常量開頭的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)

           

          -- 開頭和結(jié)尾都是%,對不起,很難優(yōu)化

           

          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)

           

          -- 以常量結(jié)束,直接寫的時候是不能應(yīng)用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)

           

          --'以常量結(jié)束的,加個reverse 函數(shù),又可以用上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)


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 云浮市| 兴仁县| 信丰县| 大足县| 昌乐县| 屯门区| 庄河市| 安塞县| 遂川县| 余干县| 大方县| 湟中县| 集贤县| 沾化县| 灵川县| 镇沅| 神池县| 奉贤区| 兴城市| 肇州县| 昌都县| 澄迈县| 五莲县| 内乡县| 行唐县| 乌鲁木齐市| 桐柏县| 西青区| 鄂州市| 含山县| 左贡县| 金乡县| 客服| 阳春市| 清苑县| 安阳县| 黄平县| 博乐市| 胶南市| 墨竹工卡县| 固阳县|