MySQL中索引失效的常见情形

MySQL中索引失效的常见状况

MySQL里对索引进行优化是提升查询性能的重要方式之一,不过有时候因为使用不当会让索引不起作用。接下来我们一同探究哪些情况下索引会失效。

1、联合索引未遵循最左前缀规则

  • 失效的例子:联合索引 (a,b,c)

    SELECT * FROM table WHERE b=1 AND c=2;  -- ❌ 索引失效
    
  • 正确的写法

    WHERE a = ?  -- ✅
    WHERE a = ? AND b = ?  -- ✅
    WHERE a = ? AND b = ? AND c = ?  -- ✅
    -- 注:MySQL对于=条件的列,优化器会按索引顺序重新整合WHERE条件,比如:
    WHERE b = ? AND a = ? AND c = ?  -- ✅ 同样会走索引
    

2、在索引列上运用函数或进行运算

  • 失效的例子

    SELECT * FROM orders WHERE YEAR(create_time) = 2025;  --  ❌ 索引失效
    
  • 正确的写法

    -- 换成范围查询
    SELECT * FROM orders 
    WHERE create_time BETWEEN '2025-01-01' AND '2025-12-31';  -- ✅
    

3、隐式的类型转换

  • 失效的例子:字段类型和查询值的类型不一致

    -- user_id 是 VARCHAR 类型
    SELECT * FROM users WHERE user_id = 1001;  -- ❌ 索引失效(数字转字符串,MySQL得把列值转成数字再比较,没法走索引)
    
  • 正确的写法

    SELECT * FROM users WHERE user_id = '1001';  -- ✅ 保证类型一致
    

4、LIKE 查询时左边加了通配符 %

  • 失效的例子

    SELECT * FROM users WHERE name LIKE '%王';  -- ❌ 索引失效
  • 正确的写法

    SELECT * FROM users WHERE name LIKE '王%';  -- ✅ 能够使用索引

5、OR连接非索引列

  • 失效的例子

    -- age 有索引,address 无索引
    SELECT * FROM users WHERE age > 25 OR address = '北京';  -- ❌ 索引失效
  • 正确的写法
    **

    -- 拆分成 UNION
    SELECT * FROM users WHERE age > 25 
    UNION
    SELECT * FROM users WHERE address = '北京';  -- ✅
    

6、使用 IS NULL / IS NOT NULL

SELECT * FROM users WHERE name IS NULL;  -- ✅ 通常能用索引
SELECT * FROM users WHERE name IS NOT NULL;  -- ❌ 索引不一定会用,一般不能用

7、NOT IN / NOT EXISTS

  • 失效的例子

    SELECT * FROM users WHERE id NOT IN (SELECT user_id FROM blacklist); -- ❌ 索引失效
  • 正确的写法

    -- 改用 LEFT JOIN
    SELECT u.* FROM users u
    LEFT JOIN blacklist b ON u.id = b.user_id
    WHERE b.user_id IS NULL;  -- ✅

有时候会碰到明明使用方法正确,但看执行计划却没走索引的情况,这有可能是数据量比较少时,MySQL自带的优化器觉得全表扫描更快。而且索引失效的情况,我只是列举了几种常见的。像重复索引、索引统计信息过期、范围查询中断联合索引等等,也都会造成索引失效。我们能够依据具体情况来进行分析,对于执行计划的解读,大家可以参考另一篇博文 MySQL EXPLAIN 关键字详解

资本的低迷时期终究会过去。-- 烟沙九洲

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12915.html

(0)
LomuLomu
上一篇 2025 年 7 月 20 日
下一篇 2025 年 7 月 20 日

相关推荐

  • 无需额外软件最新版datagrip激活码申领,实用破解教程

    免责声明:下文提到的 DataGrip 破解补丁与激活码均来源于互联网公开分享,仅供个人学习与研究,禁止任何商业用途。若条件允许,请支持正版!官方正版低至 32 元/年:https://panghu.hicxy.com/shop/?id=18 DataGrip 是 JetBrains 出品的一款跨平台数据库 IDE,支持 Windows、macOS 与 Li…

    2025 年 10 月 15 日
    34500
  • CLion激活失败后如何还原正版状态?

    声明:本教程中提到的 Clion 破解补丁与激活码均来自互联网公开渠道,仅供个人学习研究,禁止商业用途。如条件允许,请支持正版授权! JetBrains 出品的 Clion 是一款跨平台 C/C++ IDE,支持 Windows、macOS 与 Linux。下文将手把手演示如何利用破解补丁完成永久激活,解锁全部高级特性。 无论你当前系统或版本如何,所需资源已…

    2025 年 9 月 14 日
    19900
  • 最新datagrip激活码脚本运行及破解步骤

    DataGrip破解教程:2025最新版永久激活方法(附破解补丁下载和激活码) 重要提示:本教程涉及的DataGrip破解补丁及激活码均为网络收集,仅限个人学习使用,禁止商业用途。若条件允许,强烈建议购买官方正版授权。如需删除侵权内容,请联系原作者。 DataGrip作为JetBrains旗下强大的数据库管理工具,支持跨平台使用。本文将分享如何通过破解补丁实…

    DataGrip激活码 2026 年 1 月 8 日
    9100
  • 无需插件直接拿下pycharm激活码与破解教程

    免责声明:以下补丁与激活码均源自网络公开分享,仅供学习交流,禁止商业用途。若条件允许,请支持正版:https://panghu.hicxy.com/shop/?id=18 PyCharm 是 JetBrains 家族中备受推崇的 Python IDE,跨平台支持 Windows、macOS 与 Linux。下面用图文方式手把手教你通过补丁实现“永久解锁”,一…

    2025 年 10 月 19 日
    28800
  • manim边做边学–动画更新

    今天介绍Manim中用于动画更新的3个类 ,分别是: UpdateFromFunc:根据自定义的函数来动态更新 Mobject 的属性 UpdateFromAlphaFunc:根据动画的进度来平滑地改变 Mobject 的属性 MaintainPositionRelativeTo:保持多个 Mobject 之间的相对位置关系 这3个类 分别从自定义更新、基于…

    2025 年 1 月 16 日
    51900

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信