oracle可以使用强制索引,举个例子
比如在条件诸多的sql中为了确保优先正确的使用最高效的索引可以这样写
select /*+index(a,index_name)*/ * from table_name a where col_a=? and col_b=? and col_c=? and ...;
注意() 里面的a如果表有别名要用别名如果没有就用表名,这样就会强制使用你想要用的索引了。
索引失效会有很多中情况了,比如like or <>等这些都可以导致索引失效,还有隐式的转换,比如数据库里是字符,而你写的时候没有带引号,会有一个隐式的转换,也会导致索引失效,还有在列上的函数也会使索引失效,如果在该列上经常会使用函数,那么建一个函数索引会比较理想。
要看是否失效,你可以对建立索引的表进行analyze分析先,具体语句是
analyze table **** compute statistics;如果有失效索引会提示错误