MySQL索引失效场景

灰太狼 2023-10-13 19:08 142阅读 0赞

常见的导致索引失效的场景:

1、不使用索引列进行过滤:当查询中没有使用索引列作为过滤条件时,索引将无法发挥作用。例如,对于一个有索引的name列,如果查询中没有使用name作为过滤条件,而是使用其他列进行过滤,那么索引将无法生效。

  1. -- 索引失效的情况
  2. SELECT name FROM customers WHERE age > 30;
  3. -- 索引生效的情况
  4. SELECT name FROM customers WHERE name = 'John' AND age > 30;

2、列值使用函数或表达式进行操作:当查询中对索引列的值进行函数调用、类型转换或表达式计算时,索引可能无法被利用。因为索引是建立在原始列值上的,如果查询中对列值进行了操作,就无法直接使用索引进行匹配。

  1. -- 索引失效的情况
  2. SELECT name FROM customers WHERE UPPER(name) = 'JOHN';
  3. -- 索引生效的情况
  4. SELECT name FROM customers WHERE name = 'John';

3、数据表太小:当数据表中的记录非常少时,使用索引的效益可能会降低。对于小型表来说,全表扫描可能比使用索引更快速。

  1. -- 索引失效的情况
  2. SELECT name FROM small_table;
  3. -- 索引生效的情况
  4. SELECT name FROM large_table;

4、使用通配符或模糊查询:对于以通配符开头的查询模式(如LIKE ‘%keyword’)或模糊查询,索引通常无法被充分利用。因为通配符的存在,数据库需要扫描更多的索引项来匹配模式,导致索引失效。

  1. -- 索引失效的情况
  2. SELECT name FROM customers WHERE name LIKE '%John%';
  3. -- 索引生效的情况
  4. SELECT name FROM customers WHERE name LIKE 'John%';

5、OR操作符:当查询中包含OR操作符连接多个条件时,如果这些条件涉及到不同的列,索引可能无法被充分利用。对于OR操作符,数据库通常只能使用一个索引,而无法同时利用多个索引。

  1. -- 索引失效的情况
  2. SELECT name FROM customers WHERE age > 30 OR city = 'New York';
  3. -- 索引生效的情况
  4. SELECT name FROM customers WHERE age > 30 AND city = 'New York';

6、高基数列:当列中有大量重复值(低基数)时,索引的选择性下降,可能导致索引失效。索引的选择性指的是索引列不重复值的比例,选择性越高,索引的效果越好。

7、数据表过度索引:当数据表上有过多的索引时,维护这些索引的开销会增加,并且可能导致数据库选择不合适的索引而影响查询性能。

发表评论

表情:
评论列表 (有 0 条评论,142人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Mysql索引失效场景

    首先我们准备一张有800万条数据的表,在没有加索引的条件下,查询全表的某一字段所耗费的时间大致在3.6S: ![在这里插入图片描述][23a74a59f6b3414e9ee

    相关 MySQL索引失效场景

    常见的导致索引失效的场景: 1、不使用索引列进行过滤:当查询中没有使用索引列作为过滤条件时,索引将无法发挥作用。例如,对于一个有索引的name列,如果查询中没有使用name作

    相关 mysql索引类别和失效场景

    首先,我们为什么要使用索引,索引有什么作用呢? 索引可以用来快速查询数据表中有某一特定值的记录,大大加快数据的查询速度;在列上创建了索引之后,查找数据时可以直接根据该列上

    相关 mysql索引失效场景

    前言 之前有看过许多类似的文章内容,提到过一些sql语句的使用不当会导致MySQL的索引失效。还有一些MySQL“军规”或者规范写明了某些sql不能这么写,否则索引失效。