索引失效场景:
1. 模:代表模糊查询
。like的模糊查询以%开头,索引失效。 这时候如果一定要用来开头则考虑用函数索引 reverse(columnName) 两个百分号考虑用全文索引oracle全文索引(全文检索)的介绍,使用和创_weeknd的博客-优快云博客_oracle全文索引 所在表空间
2. 型:代表数据类型。类型错误,如字段类型为varchar,where条件用number(触发了隐式转换),索引也会失效。错误情况如字段为varchar 但select * from table where column= 123123
正确应该是select * from table where column= ‘123123’
3. 数:代表函数。对索引的字段使用内部函数如,索引也会失效。这种情况下应该建立基于函数的索引。如查询时用到了 round函数 就需要create index xx on test(round(id))
4. 空:是Null的意思。索引不存储空值,当我们用索引列 is not null /is null”的方式访问时,无法使用索引
,数据库会认为索引列有可能存在空值,所以不会按照索引进行计算。
5. 运:代表运算。对索引列进行+ - * / ! <> not in not exist !=等运算(会假定返回多数记录),会导致索引失效。
6. 最:代表最左原则。在复合索引中索引列的顺序至关重要。如果不是按照索引的最左列开始查找,则无法使用索引。即where 条件顺序和组合索引中各字段顺序要一致
7. 快:全表扫描更快的意思。如果数据库预计使用