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 日

相关推荐

  • MySQL 8.0 OCP英文题库深度解析(其一)

    文章标题: MySQL 8.0 OCP英文题库深度剖析(其一) 文章内容: 试题1: 选择两个选项。你的MySQL服务器由早期主要版本升级而来。sales数据库包含三个表,其中之一是transactions表,该表有400万行。你的datadir分区磁盘空间不足,开始进行排查。查看以下命令和输出:哪两个陈述是正确的? C)执行SET GLOBAL innod…

    2025 年 6 月 24 日
    22900
  • DataGrip激活码在哪里填?填错怎么补救?

    本教程同样适用于 IDEA、PyCharm、DataGrip、Goland 等 JetBrains 全家桶! 先放一张成功激活到 2099 年的截图镇楼,爽到飞起! 下面我会用图文结合的方式,手把手教你把 DataGrip 激活到 2099 年。老版本也能用,无论 Windows、macOS 还是 Linux,我都给你准备好了。 1. 下载 DataGrip…

    DataGrip激活码 2025 年 9 月 10 日
    11500
  • 最新idea激活码无限制申领与全流程破解教程

    声明:以下 IntelliJ IDEA 破解补丁、激活码均源自互联网,仅供个人学习研究,禁止商业用途。如有版权争议,请第一时间联系作者删除。若经济允许,请支持正版! IntelliJ IDEA 是 JetBrains 出品的跨平台 IDE,支持 Windows、macOS 及 Linux。下文将手把手演示如何通过离线补丁实现永久授权,一次性解锁全部高级特性。…

    IDEA破解教程 2025 年 10 月 21 日
    8000
  • PyCharm破解对账号有影响吗?是否能登录JetBrains?

    免责声明:下文所涉 PyCharm 破解补丁与激活码均源于互联网公开分享,仅限个人学习研究,禁止商业用途。若条件允许,请支持正版:https://panghu.hicxy.com/shop/?id=18 PyCharm 是 JetBrains 出品的一款跨平台 Python IDE,Windows、macOS、Linux 均可使用。下面手把手教你利用破解补丁…

    PyCharm激活码 2025 年 9 月 8 日
    17100
  • Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

    探索Java Swing的奇妙世界 目录概览 引言 核心理念 组件与容器的奥秘 GridLayout(网格布局) GridBagLayout(网格包布局) FlowLayout(流式布局) BorderLayout(边框布局) BoxLayout(箱式布局) 事件监听的艺术 引言 核心理念 Java Swing 的架构精髓 Java Swing,这个为Jav…

    2024 年 12 月 28 日
    46300

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信