Mysql、Oracle、PostgreSql数据库索引失效场景详细讲解
- 前言
前言
Mysql、Oracle、PostgreSql数据库索引失效场景详细讲解。废话不多说直接贴:
1、任何计算、函数、类型转换
2、!=、<>
3、IS NULL或者IS NOT NULL。类似导致索引失效的还有NOT IN,NOT LIKE等,但是NOT EXISTS不会导致索引失效。
4、模糊查询通配符在开头
5、索引字段在表中占比较高
6、多字段btree索引查询条件不包含第一列
7、在WHERE中使用OR时,有一个列没有索引,那么其它列的索引将不起作用
8、多字段btree索引查询条件不包含第一列
9、多字段索引查询条件使用OR
在索引列上进行大于大于这类的比较后,这个列的索引是有效的,但是其后的索引将失效
10、覆盖索引不写*
尽量使用覆盖索引,而不要用select *。示例中,如果我们业务上只需要使用username、age、gender这三个字段,那么我们就使用
select username, age, gender,而不要用select *。这是因为这三个字段在索引中就已经维护了它们的值,定位索引后,就能检索出
它们的值。如果使用select *的话,定位到索引后,由于索引没有维护city的值,所以其后还会去检索city的值,造成了时间开销.