简单说两句Like的优化

文章作者 100test 发表时间 2007:03:14 13:59:05
来源 100Test.Com百考试题网


简单说两句,具体看例子

  1。尽量不要使用 like %..%

  2。对于 like ..%.. (不以 % 开头),Oracle可以应用 colunm上的index

  3。对于 like %... 的 (不以 % 结尾),可以利用reverse function index 的形式,变化成 like ..%

  代码:

  -- 建测试表和Index,注意,重点在于带reverse的function index。同时,一定要使用CBO才行……

Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ sys@mescp> 0select reverse(123) from dual.REVERSE(123) -------------------------------- 321 1 row 0selected. sys@mescp> create table test_like as 0select object_id,object_name from dba_objects. Table created. sys@mescp> create index test_like__name on test_like(object_name). Index created. sys@mescp> create index test_like__name_reverse on test_like(reverse(object_name)). Index created. sys@mescp> analyze table test_like compute statistics for table for all indexes. Table analyzed. sys@mescp> set autotrace trace exp

  -- 常量开头的like , 会利用index ,没问题……

Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ sys@mescp> 0select * 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)


相关文章


甲骨文发布快速开发工具APEX2.2版本
如何在Oracle里用存储过程定期分割表
案例学习Oracle错误:ORA-00904
修改ORACLE的DATAFILE文件名
简单说两句Like的优化
Oracle中Instance实例和数据库的区别
OracleSpatial数据加密问题的研究
如何更改监听器日志文件名称
何时Oracle使用绑定变量性能反而更差
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛