MySQL 面试题(一):索引失效的几种情况

news2024/11/19 12:39:50

在这里插入图片描述

❤️ 博客首页:水滴技术
🚀 支持水滴:点赞👍 + 收藏⭐ + 留言💬
🌸 订阅专栏:MySQL 教程:从入门到精通

文章目录

  • 一、like 以通配符 % 开头的索引会失效
  • 二、is not null 无法使用索引,is null 可以使用索引
  • 三、表达式或函数中的索引列会失效
  • 四、联合索引未遵循最左前缀原则会失效
  • 五、or 前后出现非索引列,索引会失效
  • 热门专栏


大家好,我是水滴~~

又到了跳槽季,今天我们来看一个被高频问到的面试题:MySQL 索引失效有哪些情况?我列举了下面几种,如果小伙伴们有补充的,欢迎给我留言哦。

一、like 以通配符 % 开头的索引会失效

下面例子的 like 是以通配符 % 开头的,使用 explain 检测,typeindex,表示会遍历整个索引树,索引失效
在这里插入图片描述

可以使用以 % 结尾的语句,通过检测可以看出 type 为 range,表示只遍历给定范围的索引树,索引生效。
在这里插入图片描述

二、is not null 无法使用索引,is null 可以使用索引

下面例子使用 is not null 语句,通过检查可以看出 typeindex,表示会遍历整个索引树,索引失效
在这里插入图片描述
如果换成 is null,检测结果为 ref,索引生效。
在这里插入图片描述

三、表达式或函数中的索引列会失效

下面例子的 age 索引列为表达式的一部分,通过检测可以看出 typeall,表示为全表扫描,索引失效
在这里插入图片描述
下面例子的 name 索引列为函数的一部分,通过检测可以看出 type 为 all,表示为全表扫描,索引失效。
在这里插入图片描述

四、联合索引未遵循最左前缀原则会失效

联合索引是指对一张表上的多个字段进行索引,例如:i_abc 索引是由 (a, b, c) 三列联合创建起来的索引。
最左前缀原则是指最左匹配,以最左边字段为起点,任何连续的字段都能匹配上索引。在 (a, b, c) 联合索引中,想要索引生效,只能使用 aababcac四种组合,其它组合都会失效。所以在联合索引中,字段的顺序很重要。(注:ac 实际上只使用了 a 列的索引,因为它略过了b,不是顺序的)

下面的例子也验证了上面说的那四种组合是生效的。
在这里插入图片描述
有一点不要搞错了,最左前缀原则与 where 子句的字段顺序无关,如下面的例子,它们是生效的。
在这里插入图片描述
再来看一些索引失效的例子,它们都没有使用 a 列,所以会失效,如下图:
在这里插入图片描述

五、or 前后出现非索引列,索引会失效

如下列,字段name为索引列,而字段 height 为非索引列,中间使用 or 会导致索引失效
在这里插入图片描述


热门专栏

👍 《Python入门核心技术》
👍 《IDEA 教程:从入门到精通》
👍 《Java 教程:从入门到精通》
👍 《MySQL 教程:从入门到精通》
👍 《大数据核心技术从入门到精通》

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/191634.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SGI STL二级空间配置器源码剖析(1)

之前大概写过SGI STL相关的东西有关SGI STL,讲了讲空间配置器的原理,这一系列就剖析一下源码。 目录 下面就看看重要成员信息: 两个辅助接口函数: 关于C的STL的空间配置器allocator的实现就是分了四部分: allocate&…

云原生学习——容器的基本概念和Kubernetes 核心概念

https://developer.aliyun.com/learning/course/572/detail/7786什么是容器(Container)?什么是镜像(docker)?分层和复用运行后名称为 demo,进程是top命令二、容器的生命周期数据卷是一个特殊的目录四、容器 VS VM虚拟机一、什么是 Kubernetes…

KD:Distilling the Knowledge in a Neural Network 原理与代码解析

paper:Distilling the Knowledge in a Neural Networkcode:https://github.com/megvii-research/mdistiller/blob/master/configs/cifar100/kd.yaml存在的问题训练阶段,我们可以不考虑计算成本和训练时间,为了更高的精度训练一个很…

小程序提升篇-npm、数据共享、分包、自定义tabBar

npm 包的使用1.1 npm限制小程序支持npm第三方包,提高开发效率,有以下三种限制:不支持依赖node.js内置库包不支持依赖浏览器内置对象的包不支持依赖C插件的包限制较多,因此小程序可以使用的包不多1.2 Vant Weapp是一套开源的小程序…

带你读懂——频率响应与采样频率之间的关系

频响范围 频率响应:不同频率下的输入信号经过系统后响应之后的输出信号增益。大白话就是,输入信号频率是xxx Hz,幅值为yyy mg,观察此时的输出信号幅值为AyAyAy mg,此时升高或降低了AAA倍。 电压增益计算公式&#xff…

浅读人月神话笔记(2)

读书笔记:今日翻书浅读,从《为什么巴比伦塔会失败》开始至《干将莫邪》结束,巴比伦塔的建造对当下项目推进有广泛借鉴意义,今天这几个章节在PMBOK中有一些可以互相对照学习的内容,《为什么巴比伦塔会失败?》…

RPA自动化办公04——软件自动化(excel,word,浏览器)

参考:软件自动化_UiBot开发者指南 虽然我们可以使用前面的鼠标点击等操作打开excel表然后写入什么的,但是直接用Uibot里面的命令会更方便。 Excel 在旁边的命令里面打开excel簿 随便选一个excel表实验一下,然后读取区域,可以选。…

使用字典快速获取唯一值与重复值【单个字典对象】

在以前的博客《使用字典快速获取唯一值与重复值(交集与并集)》使用多个字典对象获取交集与并集,最近有同学提问,是否可以只使用一个字典对象实现相同的功能,对于有“编程洁癖”的同学来说,可能不喜欢使用多…

记录:windows+opencv3.4.16+vs2013+cmake编译

环境:vs2013,x64,opencv3.4.16,cmakeopencv官网:https://opencv.org/releases/1、opencv source下载:因为想用vs2013,现在opencv官网windows版安装包只有vc14和vc15了,只能自己编译了。找一个自…

良心无广的3款软件,每一款都逆天好用,且用且珍惜

闲话少说,直上干货! 1、清浊 清浊是一款强大到离谱的国产手机清理APP,追求简约至上,界面非常清爽,无任何弹弹屏广告,值得关注的是,这款软件完全免费使用,常规清理、应用清理、空文件…

活体识别4:论文笔记之《Face Spoofing Detection Using Colour Texture Analysis》

说明 本文是我对论文《Face Spoofing Detection Using Colour Texture Analysis》做的一个简单笔记。 这个论文是芬兰奥卢大学(Oulu)课题组的一篇很有代表性的论文,写于2016年,使用的是“手工特征SVM分类器”这种比较传统的方案,方案不复杂&…

吾爱2023新年红包题第三题

吾爱论坛2023年春节红包安卓题,随便玩一玩; https://www.52pojie.cn/thread-1738015-1-1.html 第三题:https://www.52pojie.cn/home.php?modtask&doview&id22 首先我们下载后,打开apk是提示要点击 999次即可通关&…

Docker - 4. Docker 帮助启动类命令

目录 1. 启动 docker 2. 停止 docker 3. 重启 docker 4. 查看 docker 状态 5. 保持开机自动启动 6. 显示 docker 版本信息 7. 显示 docker 系统信息 8. 查看 docker 总体帮助文档 9. 查看 docker 命令帮助文档 1. 启动 docker systemctl start docker 2. 停止 dock…

macm1安装tensorflow以及pycharm配置

macm1安装tensorflow以及pycharm配置 本文目录macm1安装tensorflow以及pycharm配置使用MacOS 12安装conda创建一个conda环境安装tensorflowpycharm配置使用MacOS 12 必需条件:macOS 12 安装conda 安装Miniforge(包含conda及一个python环境)…

RabbitMQ消息队列实战(2)—— Java调用RabbitMQ的三种方式

本文主要介绍Java中调用RabbitMQ的三种方式。三种方式实际上对应了三种不同的抽象级别:首先,通过Java原生代码来访问RabbitMQ。在这种方式下,需要手动创建Connection,创建Channel,然后通过Channel对象可以显式的创建Ex…

基于springboot+vue的问卷调查系统(前后端分离)

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容:毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 功能分析…

学校机房高效稳定,一招见效

校园安全作为公共安全领域重要的一部分,一直以来都格外受到重视。近年来,各地区陆续发布了多项加强校园安全管理的政策、法规及标准规范,旨在贯彻落实构建“平安校园”的宗旨,不断完善校园的人防、物防、技防建设。 学校机房常见四…

AutoLisp演练(二)

一、自动绘制出多个等半径圆相切 1.输入基准点baspt 2.输入小圆半径rad 3. 输入欲相切的圆的数量num 4.自动绘制出多个等半径圆相切 5. 涉及到相关变量,设定为baspt、rad、num、midpt、cenpt、kk、ang1、ang2 二、程序代码实现 三、测试及效果 测试一 四、…

盘点一些惊艳一时的 CSS 属性

✨ 个人主页:山山而川~xyj ⚶ 作者简介:前端领域新星创作者,专注于前端各领域技术,共同学习共同进步,一起加油! 🎆 系列专栏: web 大前端 🚀 学习格言:与其临…

2023爬虫学习笔记 -- 某狗网站爬取数据

一、爬取某狗网站的首页1、导入需要的库文件import requests2、指定我们要访问的网址网页"https://www.sogou.com"3、获取服务器的返回的所有信息响应requests.get(网页)4、通过text属性,从返回信息中读取字符串内容响应内容响应.text5、查看读取到的内容…