1.隐式转换导致索引失效.这一点应当引起重视.也是开发中经常会犯的错误.

  由于表的字段tu_mdn定义为varchar2(20),但在查询时把该字段作为number类型以where条件传给Oracle,这样会导致索引失效.

 错误的例子:select * from test where tu_mdn=13333333333;

 正确的例子:select * from test where tu_mdn='13333333333';


  错误的例子:select * from test where id-1=9;

 正确的例子:select * from test where id=10;


       错误的例子:select * from test where round(id)=10; 说明,此时id的索引已经不起作用了

       round(id)=10; 这时函数索引起作用了


  a. 使用 <> 、not in 、not exist、!=

 b. like "%_" 百分号在前(可采用在建立索引时用reverse(columnName)这种方法处理)

       列被where子句引用时,优化器才会选择使用该索引。

 d. 字符型字段为数字时在where条件里不添加引号.

 e. 当变量采用的是times变量,而表的字段采用的是date变量时.或相反情况。

 


  


 


     8. Oracle默认使用的基于代价的SQL优化器(CBO)非常依赖于统计信息,一旦统计信息不正常,会导致数 据库查询时不使用索引或使用错误的索引。

     20%),可以考虑立即手动更新统计信息,例如:analyze table abc compute statistics,但注意,更新统计 信息比较耗费系统资源,建议在系统空闲时执行。


     和索引 2 ( classcode ),如果查询条件为  policyno =  ‘ xx ’  and classcode =  ‘ xx ’ ,则系统有可能会使用索引 2,相较于使用索引1,查询效率明显降低。