MySQL避免索引失效的方法示例

 更新时间:2024年08月12日 08:31:36   作者:攒了一袋星辰  
索引是帮助MySQL高效获取数据的数据结构,本文主要介绍了MySQL避免索引失效的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

避免索引失效

在MySQL中,索引是帮助MySQL高效获取数据的数据结构。它就像一本书的目录,通过索引可以快速定位到数据的具体位置,从而减少对数据库的扫描量,提高查询速度。索引可以存储在表中的一个或多个列上,创建索引后可以大大加快数据的检索速度,但也会占用额外的磁盘空间,并且在数据插入、删除和更新时需要对索引进行维护,这可能会降低这些操作的性能

尽管索引能显著提升查询性能,但在某些情况下,索引可能会失效,导致查询性能并未达到预期。以下是一些常见的导致索引失效的情况:

全值匹配:

通常,当你对索引中的所有列都指定了具体值时,索引会生效。但是,这里提到的“避免索引失效”更多是指在其他情况下,因为全值匹配本身就是为了利用索引的。

假设有一个表employees,上面有一个索引(first_name, last_name)

SELECT * FROM employees WHERE first_name = 'John' AND last_name = 'Doe';

这个查询将全值匹配索引中的所有列,因此索引会生效。

最左前缀法则:

对于复合索引(即索引包含多个列),MySQL会遵循最左前缀法则。这意味着,在查询条件中,如果索引列不是以索引中的第一个列开始,则索引可能不会被使用。例如,如果有一个索引是(A, B, C),那么查询条件中只有A、A和B、A和B和C的组合才能有效利用索引,而只有B或B和C的组合则不会。

继续使用上面的employees表和索引(first_name, last_name)

SELECT * FROM employees WHERE first_name = 'John';  
SELECT * FROM employees WHERE first_name = 'John' AND last_name = 'Doe';
SELECT * FROM employees WHERE last_name = 'Doe';
  • 有效利用索引的查询:
  • 不会利用索引的查询(仅针对last_name):

使用函数或计算:

如果在索引列上使用了函数或进行了计算,那么索引可能不会被使用。例如,如果有一个索引在列date_col上,但查询条件为YEAR(date_col) = 2023,那么索引可能不会被利用。

假设employees表有一个日期列hire_date,并且该列上有索引。

-- 索引可能不会被利用  
SELECT * FROM employees WHERE YEAR(hire_date) = 2020;

相比之下,如果查询条件没有使用函数:

-- 索引会被利用  
SELECT * FROM employees WHERE hire_date >= '2020-01-01' AND hire_date < '2021-01-01';

隐式类型转换:

如果索引列的数据类型和查询条件中的数据类型不一致,并且MySQL需要进行隐式类型转换来匹配它们,那么索引可能不会被使用。

-- 隐式类型转换,索引可能不会被利用  
SELECT * FROM employees WHERE employee_id = 123;  -- 假设employee_id是字符串类型,但查询中使用了数字

如果employee_id是数字类型,则索引会被利用。

例子

-- 索引可能不会被有效利用(取决于MySQL优化器的决定)  
SELECT * FROM employees WHERE first_name != 'John';

使用不等于(!= 或 <>)操作符:

使用不等于操作符时,MySQL可能会选择全表扫描而不是使用索引,特别是当查询条件中的列是索引列时。

-- 索引可能不会被有效利用(取决于MySQL优化器的决定)  
SELECT * FROM employees WHERE first_name != 'John';

使用IS NULL 或 IS NOT NULL:

对于索引列,使用IS NULLIS NOT NULL条件可能会导致索引失效,尽管这取决于MySQL的版本和具体的查询优化器行为。

-- 对于索引列,IS NULL 或 IS NOT NULL 可能导致索引失效(取决于MySQL版本和查询优化器)  
SELECT * FROM employees WHERE email IS NULL;  -- 假设email列上有索引

LIKE以通配符开始:

当使用LIKE操作符并且模式以通配符(如%)开始时,MySQL可能无法使用索引。例如,name LIKE '%abc'不会利用name列上的索引。

如果仅仅是尾部模糊匹配,索引不会失效。如果是头部模糊匹配,索引失效。

1.explain select * from tb_seller where name like '脚本之家%';
2.explain select * from tb_seller where name like '%脚本之家';
3.explain select * from tb_seller where name like '%脚本之家%';

OR条件:

当查询条件包含OR时,如果OR连接的两个条件分别指向不同的索引列,MySQL可能无法有效地使用索引。

-- 如果OR连接的两个条件分别指向不同的索引列,MySQL可能无法有效地使用索引  
SELECT * FROM employees WHERE first_name = 'John' OR last_name = 'Doe';

索引列参与计算或函数:

如果索引列参与了计算或函数操作,则可能导致索引失效。

-- 索引列参与了计算,索引可能不会被利用  
SELECT * FROM employees WHERE first_name = CONCAT('J', 'ohn');

到此这篇关于MySQL避免索引失效的方法示例的文章就介绍到这了,更多相关MySQL避免索引失效内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • mysql 使用存储过程实现树节点的获取方法

    mysql 使用存储过程实现树节点的获取方法

    这篇文章主要介绍了mysql 使用存储过程实现树节点的获取方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • mysql输入中文出现ERROR 1366的解决方法

    mysql输入中文出现ERROR 1366的解决方法

    这篇文章主要为大家详细介绍了mysql输入中文出现ERROR 1366的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • MySQL数据库高级查询和多表查询

    MySQL数据库高级查询和多表查询

    这篇文章主要介绍了MySQL数据库高级查询和多表查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • MySQL怎么给字符串字段加索引

    MySQL怎么给字符串字段加索引

    本文主要介绍了MySQL怎么给字符串字段加索引,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 浅谈MySQL数据库的备份与恢复

    浅谈MySQL数据库的备份与恢复

    MYSQL数据库的备份、恢复等是每一位信息管理人员应必备的能力,因此掌握MYSQL数据库管理的技巧会使您的工作事半功倍,这里我们来简单总结下。
    2017-01-01
  • 查看修改MySQL表结构命令

    查看修改MySQL表结构命令

    这篇文章主要介绍了查看修改MySQL表结构命令,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • MySQL DNS的使用过程详细分析

    MySQL DNS的使用过程详细分析

    当 mysql 客户端连接 mysql 服务器 (进程为:mysqld),mysqld 会创建一个新的线程来处理该请求。该线程先检查是否主机名在主机名缓存中
    2012-11-11
  • mysql 正则表达式查询含有非数字和字符的记录

    mysql 正则表达式查询含有非数字和字符的记录

    这篇文章主要介绍了mysql 正则表达式查询含有非数字和字符的记录的相关资料,需要的朋友可以参考下
    2016-12-12
  • MySQL性能压力基准测试工具sysbench的使用简介

    MySQL性能压力基准测试工具sysbench的使用简介

    这篇文章主要介绍了MySQL性能压力基准测试工具sysbench的使用简介,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-04-04
  • 读取mysql一个库下面的所有的表table

    读取mysql一个库下面的所有的表table

    本文给大家分享的是如何使用php实现读取mysql一个库下面的所有的表table的代码,有需要的小伙伴可以参考下
    2016-12-12

最新评论