当前位置: 首页 > news >正文

索引失效的14种常见场景

在 MySQL 中,索引有时可能会失效,导致查询性能下降。以下是常见的 14 种场景,在这些场景下,索引可能会失效

1. 使用 OR 连接多个条件

  • 场景: 当查询中包含 OR 时,如果 OR 连接的多个条件中有一个没有使用索引,可能会导致索引失效。
  • 例子:
    SELECT * FROM employees WHERE age = 30 OR name = 'John';
    这个查询中, age = 30 可能使用索引,但 name = 'John' 没有索引时,MySQL 会放弃使用索引。

2. 在查询中使用函数

  • 场景: 如果查询中在索引列上应用了函数,索引可能失效。
  • 例子:
    SELECT * FROM employees WHERE YEAR(birthdate) = 1990;
    这里对 birthdate 使用了 YEAR() 函数,导致索引失效。

3. 使用 LIKE 开头的模糊匹配

  • 场景: 当 LIKE 操作符以通配符 % 开头时,索引会失效。
  • 例子:
    SELECT * FROM employees WHERE name LIKE '%John';
    由于 % 位于开头,MySQL 无法使用索引优化查询。

4. 在查询条件中使用 NOT

  • 场景: 使用 NOT 操作符时,索引可能会失效,尤其是与 INLIKE 一起使用时。
  • 例子:
    SELECT * FROM employees WHERE NOT age = 30;
    NOT 会导致索引失效,MySQL 可能会选择全表扫描。

5. 使用 IS NULLIS NOT NULL

  • 场景: 当查询条件使用 IS NULLIS NOT NULL 时,索引可能不会被使用。
  • 例子:
    SELECT * FROM employees WHERE salary IS NULL;
    使用 IS NULL 时,索引可能不会被有效利用。

6. 范围查询后再进行其他条件筛选

  • 场景: 使用范围查询( BETWEEN<> 等)后,再添加其他条件,索引可能失效。
  • 例子:
    SELECT * FROM employees WHERE age BETWEEN 30 AND 40 AND name = 'John';
    这里, age 使用了范围查询, name 的条件可能无法使用索引。

7. 联合索引的列顺序不匹配

  • 场景: 使用联合索引时,如果查询的列顺序与索引创建时的顺序不匹配,索引可能会失效。
  • 例子:
    CREATE INDEX idx_name_age ON employees (name, age);
    SELECT * FROM employees WHERE age = 30 AND name = 'John';
    如果 age 在联合索引中排在 name 后面,这种查询会导致索引失效。

8. 使用 DISTINCTGROUP BY

  • 场景: 如果查询中使用了 DISTINCTGROUP BY,索引可能无法被完全利用。
  • 例子:
    SELECT DISTINCT name FROM employees WHERE age = 30;
    DISTINCTGROUP BY 可能导致索引不完全被利用。

9. 在查询中使用 LIMIT

  • 场景: 当查询包含 LIMIT 子句时,如果没有明确的排序索引,MySQL 可能无法使用索引。
  • 例子:
    SELECT * FROM employees WHERE age = 30 LIMIT 10;
    如果没有 ORDER BY,MySQL 可能不会使用索引来限制结果数量。

10. 数据类型不匹配

  • 场景: 如果查询中使用的列的数据类型与索引列的数据类型不匹配,可能导致索引失效。
  • 例子:
    SELECT * FROM employees WHERE salary = '30000';
    如果 salaryINT 类型,而查询中使用了字符串类型的 30000,索引可能失效。

11. 使用 JOIN 时连接条件没有使用索引

  • 场景: 当连接条件( ON 子句)没有涉及索引时,索引会失效。
  • 例子:
    SELECT * FROM employees e JOIN departments d ON e.department_id = d.id;
    如果 department_id 没有索引,查询可能会进行全表扫描。

12. 使用 OR 和不等于条件(<>

  • 场景: 使用 OR 连接时,如果条件中有不等于( <>)操作符,索引可能失效。
  • 例子:
    SELECT * FROM employees WHERE department_id = 1 OR department_id <> 2;
    这种情况下,索引可能无法完全利用。

13. 字符串拼接或连接运算

  • 场景: 当查询条件中对列进行拼接或连接运算时,索引会失效。
  • 例子:
    SELECT * FROM employees WHERE CONCAT(first_name, ' ', last_name) = 'John Doe';
    这种字符串连接操作会导致索引无法使用。

14. 隐式类型转换

  • 场景: 如果查询中对列进行隐式类型转换,索引可能无法使用。
  • 例子:
    SELECT * FROM employees WHERE salary = '30000.00';
    如果 salary 列是 FLOAT 类型,而查询使用了字符串 '30000.00',这可能导致隐式类型转换,从而使索引失效。

总结

  • 常见原因: 使用 OR、函数、范围查询、 LIKE 开头、 NOTIS NULLDISTINCT 等。
  • 避免策略: 尽量避免在查询条件中使用这些情况,或者使用合适的索引(如组合索引、覆盖索引)来优化查询。

本文由 mdnice 多平台发布

相关文章:

索引失效的14种常见场景

在 MySQL 中&#xff0c;索引有时可能会失效&#xff0c;导致查询性能下降。以下是常见的 14 种场景&#xff0c;在这些场景下&#xff0c;索引可能会失效 1. 使用 OR 连接多个条件 场景: 当查询中包含 OR 时&#xff0c;如果 OR 连接的多个条件中有一个没有使用索引&#xff0…...

解决com.kingbase8.util.KSQLException: This _connection has been closed.

问题描述 一个消息管理系统,系统采用kingbase8数据库,数据库采用单体模式,后台应用也采用springboot单体模式。系统正式上线后,出现几个JDBC响应的异常信息: com.kingbase8.util.KSQLException: An I/O error occurred while sending to the backend.java.net.SocketTime…...

openAI官方prompt技巧(二)

1. 赋予 ChatGPT 角色 为 ChatGPT 指定一个角色&#xff0c;让其从特定的身份或视角回答问题。这有助于生成针对特定受众或场景的定制化回答。 例如&#xff1a; 你是一名数据分析师&#xff0c;负责我们的市场营销团队。请总结上个季度的营销活动表现&#xff0c;并强调与未…...

【非 root 用户下全局使用静态编译的 FFmpeg】

在非 root 用户下全局使用静态编译的 FFmpeg&#xff0c;可以按照以下方法操作&#xff1a; 1. 下载静态编译的 FFmpeg 如果你还没有下载静态编译的 FFmpeg&#xff0c;可以从官方网站获取&#xff1a; wget https://johnvansickle.com/ffmpeg/releases/ffmpeg-release-amd6…...

【嵌入式 Linux 音视频+ AI 实战项目】瑞芯微 Rockchip 系列 RK3588-基于深度学习的人脸门禁+ IPC 智能安防监控系统

前言 本文主要介绍我最近开发的一个个人实战项目&#xff0c;“基于深度学习的人脸门禁 IPC 智能安防监控系统”&#xff0c;全程满帧流畅运行。这个项目我目前全网搜了一圈&#xff0c;还没发现有相关类型的开源项目。这个项目只要稍微改进下&#xff0c;就可以变成市面上目前…...

前端布局与交互实现技巧

前端布局与交互实现技巧 1. 保持盒子在中间位置 在网页设计中&#xff0c;经常需要将某个元素居中显示。以下是一种常见的实现方式&#xff1a; HTML 结构 <!doctype html> <html lang"en"> <head><meta charset"UTF-8"><m…...

idea 找不到或者无法加载主类

idea项目&#xff0c;之前一直是正常运行的&#xff0c;放假了之后再回来就遇到启动不了的问题。 WebApplication这个类右键运行的时候&#xff0c;也提示找不到主类。 对于这种之前运行没有问题&#xff0c;突然出问题的项目。 我的点是没有改动代码和数据的情况下项目就跑不起…...

Flink 调用海豚调度器 SQL 脚本实现1份SQL流批一体化的方案和可运行的代码实例

目录 一、流批一体化概述 二、Flink 与海豚调度器结合实现流批一体化的好处 2.1 代码复用性增强 2.2 开发和维护成本降低 2.3 数据一致性保证 2.4 提高系统的灵活性和可扩展性 三、实现思路步骤 3.1 环境准备 3.2 编写 SQL 脚本并上传到海豚调度器 3.3 实现资源下载功…...

ES6 Map 数据结构是用总结

1. Map 基本概念 Map 是 ES6 提供的新的数据结构&#xff0c;它类似于对象&#xff0c;但是"键"的范围不限于字符串&#xff0c;各种类型的值&#xff08;包括对象&#xff09;都可以当作键。Map 也可以跟踪键值对的原始插入顺序。 1.1 基本用法 // 创建一个空Map…...

go结构体详解

结构体简介 Golang 中没有“类”的概念&#xff0c;Golang 中的结构体和其他语言中的类有点相似。和其他面向对象语言中的类相比&#xff0c;Golang 中的结构体具有更高的扩展性和灵活性。 Golang 中的基础数据类型可以表示一些事物的基本属性&#xff0c;但是当我们想表达一…...

机器学习-关于线性回归的表示方式和矩阵的基本运算规则

最近在学习机器学习的过程中&#xff0c;发现关于线性回归的表示和矩阵的运算容易费解&#xff0c;而且随着学习的深入容易搞混&#xff0c;因此特意做了一些研究&#xff0c;并且记录下来和大家分享。 一、线性模型有哪些表示方式&#xff1f; 器学习中&#xff0c;线性模型…...

kafka 3.5.0 raft协议安装

前言 最近做项目&#xff0c;需要使用kafka进行通信&#xff0c;且只能使用kafka&#xff0c;笔者没有测试集群&#xff0c;就自己搭建了kafka集群&#xff0c;实际上笔者在很早之前就搭建了&#xff0c;因为当时还是zookeeper&#xff08;简称ZK&#xff09;注册元数据&#…...

后台管理系统网页开发

CSS样式代码 /* 后台管理系统样式文件 */ #container{ width:100%; height:100%; /* background-color:antiquewhite;*/ display:flex;} /* 左侧导航区域:宽度300px*/ .left{ width:300px; height: 100%; background-color:#203453; display:flex; flex-direction:column; jus…...

使用一个大语言模型对另一个大语言模型进行“调教”

使用一个大语言模型对另一个大语言模型进行“调教”&#xff08;通常称为微调或适配&#xff09;&#xff0c;是一种常见的技术手段&#xff0c;用于让目标模型更好地适应特定的任务、领域或风格。以下是基于搜索结果整理的详细步骤和方法&#xff1a; 1.准备工作 安装必要的…...

golang使用sqlite3,开启wal模式,并发读写

因为sqlite是基于文件的&#xff0c;所以默认情况下&#xff0c;sqlite是不支持并发读写的&#xff0c;即写操作会阻塞其他操作&#xff0c;同时sqlite也很容易就产生死锁。 但是作为一个使用广泛的离线数据库&#xff0c;从sqlite3.7.0版本开始&#xff08;SQLite Release 3.…...

如何利用maven更优雅的打包

最近在客户现场部署项目&#xff0c;有两套环境&#xff0c;无法连接互联网&#xff0c;两套环境之间也是完全隔离&#xff0c;于是问题就来了&#xff0c;每次都要远程到公司电脑改完代码&#xff0c;打包&#xff0c;通过网盘&#xff08;如果没有会员&#xff0c;上传下载慢…...

音频进阶学习十二——Z变换一(Z变换、收敛域、性质与定理)

文章目录 前言一、Z变换1.Z变换的作用2.Z变换公式3.Z的状态表示1&#xff09; r 1 r1 r12&#xff09; 0 < r < 1 0<r<1 0<r<13&#xff09; r > 1 r>1 r>1 4.关于Z的解释 二、收敛域1.收敛域的定义2.收敛域的表示方式3.ROC的分析1&#xff09;当 …...

cursor指令工具

Cursor 工具使用指南与实例 工具概览 Cursor 提供了一系列强大的工具来帮助开发者提高工作效率。本指南将通过具体实例来展示这些工具的使用方法。 1. 目录文件操作 1.1 查看目录内容 (list_dir) 使用 list_dir 命令可以查看指定目录下的文件结构: 示例: list_dir log…...

MySQL 主从读写分离实现方案(一)—MariaDB MaxScale实现mysql8读写分离

一&#xff1a;MaxScale 是干什么的&#xff1f;? MaxScale是maridb开发的一个mysql数据中间件&#xff0c;其配置简单&#xff0c;能够实现读写分离&#xff0c;并且可以根据主从状态实现写库的自动切换&#xff0c;对多个从服务器能实现负载均衡。 二&#xff1a;MaxScale …...

阿里云 | DeepSeek人工智能大模型安装部署

ModelScope是阿里云人工智能大模型开源社区 ModelScope网络链接地址 https://www.modelscope.cn DeepSeek模型库网络链接地址 https://www.modelscope.cn/organization/deepseek-ai 如上所示&#xff0c;在阿里云人工智能大模型开源社区ModelScope中&#xff0c;使用阿里云…...

如何快速掌握tsMuxer:视频无损封装的终极指南

如何快速掌握tsMuxer&#xff1a;视频无损封装的终极指南 【免费下载链接】tsMuxer tsMuxer is a transport stream muxer for remuxing/muxing elementary streams, EVO/VOB/MPG, MKV/MKA, MP4/MOV, TS, M2TS to TS to M2TS. Supported video codecs H.264/AVC, H.265/HEVC, V…...

通过 Taotoken 用量看板分析各模型消耗并优化 Token 使用策略

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 通过 Taotoken 用量看板分析各模型消耗并优化 Token 使用策略 作为项目管理者&#xff0c;在引入多个大模型 API 支持不同业务场景…...

矢量图转换实战指南:5步实现PNG到SVG的无损升级方案

矢量图转换实战指南&#xff1a;5步实现PNG到SVG的无损升级方案 【免费下载链接】vectorizer Potrace based multi-colored raster to vector tracer. Inputs PNG/JPG returns SVG 项目地址: https://gitcode.com/gh_mirrors/ve/vectorizer 在数字设计领域&#xff0c;你…...

解锁音乐自由:3分钟让QQ音乐加密音频随处播放的终极方案

解锁音乐自由&#xff1a;3分钟让QQ音乐加密音频随处播放的终极方案 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾经在QQ音乐下载了一首心爱的歌曲&#xff0c;却…...

零基础入门ModTheSpire:5分钟学会《杀戮尖塔》模组加载神器

零基础入门ModTheSpire&#xff1a;5分钟学会《杀戮尖塔》模组加载神器 【免费下载链接】ModTheSpire External mod loader for Slay The Spire 项目地址: https://gitcode.com/gh_mirrors/mo/ModTheSpire 想要为《杀戮尖塔》注入全新活力&#xff0c;但担心破坏原版游戏…...

taotoken api key的权限细分与审计日志对安全管理的价值

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 taotoken api key的权限细分与审计日志对安全管理的价值 在构建基于大模型的应用时&#xff0c;API Key 的管理往往是安全链条中最…...

免费快速搞定CTF MISC难题:5个PuzzleSolver实战技巧让你秒变大神

免费快速搞定CTF MISC难题&#xff1a;5个PuzzleSolver实战技巧让你秒变大神 【免费下载链接】PuzzleSolver 一款针对CTF竞赛MISC的工具~ 项目地址: https://gitcode.com/gh_mirrors/pu/PuzzleSolver 你是不是每次参加CTF比赛&#xff0c;看到MISC题目就头疼&#xff1f…...

5分钟掌握NCM解密:网易云音乐文件转换终极指南

5分钟掌握NCM解密&#xff1a;网易云音乐文件转换终极指南 【免费下载链接】ncmdumpGUI C#版本网易云音乐ncm文件格式转换&#xff0c;Windows图形界面版本 项目地址: https://gitcode.com/gh_mirrors/nc/ncmdumpGUI 你是否曾经遇到过这样的情况&#xff1a;在网易云音…...

机器学习因果推断:SSRI与RI方法如何解决异质性效应估计的不确定性

1. 项目概述与核心挑战在实证研究的工具箱里&#xff0c;因果推断正变得越来越“智能”。我们不再满足于回答“这个药平均来看有没有效”&#xff0c;而是迫切想知道“这个药对张三、李四、王五分别有多大效果&#xff1f;”。这就是异质性处理效应估计的魅力所在&#xff0c;它…...

聚合芘环石墨炔:机器学习模拟揭示新型二维碳负极材料的储锂潜力

1. 项目概述&#xff1a;从石墨烯到PolyPyGY&#xff0c;二维碳负极材料的进阶之路在锂离子电池这个已经相当成熟的领域里&#xff0c;负极材料的创新一直是推动能量密度和功率密度突破的关键。从早期的石墨&#xff0c;到后来的硅基材料&#xff0c;再到如今备受瞩目的二维材料…...