索引失效主因是查询条件与索引结构不匹配。WHERE中对索引列用函数(如YEAR(create_time))导致无法使用索引而全表扫描;应改写为范围查询:create_time >= '2023-01-01' AND create_time
索引不是写了就生效的——绝大多数索引失效问题,根源不在 SQL 写得“错”,而在查询条件与索引结构的匹配被悄悄破坏了。
WHERE 条件中对索引列使用函数或表达式
MySQL 无法直接用索引定位经过计算的值,会退化为全表扫描。
SELECT * FROM users WHERE YEAR(create_time) = 2023→create_time索引失效;应改写为create_time >= '2023-01-01' AND create_timeWHERE UPPER(name) = 'ALICE'→name索引失效;可建函数索引(MySQL 8.0+):CREATE INDEX idx_name_upper ON users ((UPPER(name))),或应用层统一大小写- 隐式类型转换也属此类:如
WHERE user_id = '123'(user_id是INT),MySQL 会把索引列转为字符串比对,导致索引失效LIKE 查询以通配符开头
前导 % 让 B+ 树无法从左到右匹配前缀,索引只能用于跳过扫描(range)或完全失效。
WHERE name LIKE '%abc'→ 索引完全失效WHERE name LIKE 'abc%'→ 可走索引(最左前缀匹配)WHERE name LIKE '%abc%'→ 失效;若必须模糊搜,考虑FULLTEXT索引或 Elasticsearch- 注意:即使有复合索引
(a, b, c),WHERE a = 1 AND b LIKE '%x'中c也无法被索引覆盖OR 条件中部分字段无索引
只要 OR 中任一条件列没索引,整个 WHERE 子句可能放弃使用索引(尤其 MySQL 5.6 之前)。
WHERE status = 1 OR phone = '138...',若phone无索引 → 全表扫描- 解决方式:确保 OR 所有分支字段都有独立索引,或改用
UNION拆分(每个子查询可独立走索引)- MySQL 5.7+ 优化器有所改进,但仍建议用
EXPLAIN验证:看type是否为index_merge,且key显示多个索引名隐式字符集/排序规则不一致
当关联字段或比较字段的
collation不同(如utf8mb4_0900_as_csvsutf8mb4_general_ci),索引无法复用。
- 常见于 JOIN:左表
user.name是utf8mb4_unicode_ci,右表log.user_name是utf8mb4_bin→ 即使都建了索引,JOIN 时也可能不走索引- 排查命令:
SHOW FULL COLUMNS FROM table_name查Collation列- 修复:统一字符集和排序规则,或显式加
COLLATE强制对齐(但会抑制索引)真正难排查的,往往是多个小因素叠加:比如
OR + 函数 + 隐式转换同时出现,EXPLAIN显示type=ALL却看不出哪一环断了。建议从执行计划入手,逐条核对key、possible_keys、rows和Extra(尤其是Using filesort或Using temporary)——这些才是索引是否实际生效的铁证。
0
0
相关文章
复合索引顺序错误导致索引失效的常见 SELECT 写法
MySQL 虚拟列 STORED vs VIRTUAL 的存储与查询性能对比
MySQL EXPLAIN FORMAT=JSON 中的 cost 与 rows_examined 解读
SQL 如何监控 max_connections 被占满的告警与临时扩容
LIKE ‘%keyword%’ 导致全表扫描的全文索引 / ngram 替代方案
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。
727
2023.10.12
SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。
327
2023.10.27
在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。
350
2024.02.23
SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。
1242
2024.03.06
sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。
360
2024.03.06
运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。
820
2024.04.07
sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。
423
2024.04.29
2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。
158
2026.01.28
热门下载
相关下载
精品课程
最新文章



