Mysql索引失效场景
Mysql索引失效场景
序言

正文
1、or使用不恰当
例如:User表中的两个字段ID、Name,ID本身为主键,那么Mysql会为该字段默认添加聚簇索引;而Name却没有建立索引,如果,在查询条件 ID=12 or Name ='Jay'中,由于ID存在索引那么Mysql本应该走索引进行查询,但是。or关键词的使用导致最后会查询满足另一个条件Name ='Jay',此条件却没有索引,那么意味着必须走全局检索;Mysql此时就会优化查询逻辑,字段ID也不会走索引(因为没有必要了,在全文检索Name时额外加入ID条件就行了),这样就能避免第二次查询
select ID,name from user where ID = 12 or name = 'jay'
--ID 存在索引,name不存在索引,优化原因统一不走索引
2、最左匹配原则
想要完全理解最左匹配原则,则需要理解Mysql中的索引树- B+ TREE,了解B+ TREE后理解最左匹配原则就非常容易了;

如上图所示,在Mysql组合索引中建立的索引匹配则是从最左往右进行匹配,如果,左边成立才会匹配邻近的下一个组合索引值,例如:组合索name,like组成,而查询的条件则是name ='jay',这时就会匹配组合索引name='jay'数据,如果,条件like='rapper'时则无法触发索引,因为,索引匹配原则遵循的就是最左匹配
3、not in not exists != <>
上述关键字和表达式无法触发索引,原因是无法通过索引匹配数据,只能通过全文遍历数据。
4、like %最左包含
like %最左包含会触发数据库的全文检索,检索时间会跟随数据而增长。
5、使用内置函数
在Mysql中的条件表达列中将Mysql内置函数作为第一人称条件会导致不走索引的情况,这钟情况下将内置函数至于第三人称即可。
6、索引参与运算、多个索引列进行比较
索引列参与运算也会导致索引失效。
7、联表查询时各表编码集不一致
在使用多个表进行连接查询时,如果,各表之间的编码字符集不一致也会导致不走索引情况出现。
8、表中的数据量少
Mysql中会存在Sql查询/优化器,该优化器会优化用户组织的T-SQL语句和查询逻辑;如果表中的数据量太少,这种情况下则不用走索引查询,因为,全文遍历所耗费的时间很少。
9、没有创建索引
10、select*
使用select*时也会导致不走索引的情况出现;在阿里开发手册中,不建议使用*,无论是从编码逻辑还是执行速度上都不建议。
11、隐式转换
在查询表达式中使用与字段不对应的数据类型时,也会导致不走索引的情况出现。
总结
通过Mysql explain关键字可以解释当前sql执行情况,从而分析每个阶段查询的耗时情况,索引引用的情况。
Mysql索引失效场景的更多相关文章
- Mysql 索引失效场景
例如:一张USER表 有字段属性 name,age 其中name为索引 下面列举几个索引失效的情况 1. select * from USER where name=‘xzz’ or age= ...
- 《MySQL面试小抄》索引失效场景验证
我是肥哥,一名不专业的面试官! 我是囧囧,一名积极找工作的小菜鸟! 囧囧表示:小白面试最怕的就是面试官问的知识点太笼统,自己无法快速定位到关键问题点!!! 本期主要面试考点 面试官考点之什么情况下会索 ...
- MySQL索引失效的常见场景
当然请记住,explain是一个好习惯! MySQL索引失效的常见场景 在验证下面的场景时,请准备足够多的数据量,因为数据量少时,MySQL的优化器有时会判定全表扫描无伤大雅,就不会命中索引了. 1. ...
- MySQL索引失效之隐式转换
常见索引失效: 1. 条件索引字段"不干净":函数操作.运算操作 2. 隐式类型转换:字符串转数值:其他类型转换 3. 隐式字符编码转换:按字符编码数据长度大的方向转换,避免数据截 ...
- 面试突击60:什么情况会导致 MySQL 索引失效?
为了验证 MySQL 中哪些情况下会导致索引失效,我们可以借助 explain 执行计划来分析索引失效的具体场景. explain 使用如下,只需要在查询的 SQL 前面添加上 explain 关键字 ...
- mysql索引总结(4)-MySQL索引失效的几种情况
mysql索引总结(1)-mysql 索引类型以及创建 mysql索引总结(2)-MySQL聚簇索引和非聚簇索引 mysql索引总结(3)-MySQL聚簇索引和非聚簇索引 mysql索引总结(4)-M ...
- 面试题: MySQL 索引失效的10大原因
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 1.建表: CREATE TABLE staffs ( id INT PRIMARY KEY AUTO_ ...
- MySQL索引失效的几种场景
我们都知道建立索引能够提高查询效率,那么是不是任何情况下都能提高呢,当然不是的的,下面我们就来列举一些常见的索引失效的场景. 借用上一篇文章的dm_person_info表 在card_code列没加 ...
- 3、MySQL 索引失效的场景
索引失效的场景: 1.没有 where 条件 直接看 SQL 语句 2.where 条件中所在的列没有建立索引 show index from t; 3.从表中取得数据超过某个阈值.通常认为是 ...
- MySQL 索引失效-模糊查询,最左匹配原则,OR条件等。
索引失效 介绍 索引失效就是我们明明在查询时的条件为索引列(包括自己新建的索引),但是索引不能起效,走的是全表扫描.explain 后可查看type=ALL. 这是为什么呢? 首先介绍有以下几种情况索 ...
随机推荐
- MQTT 客户端 MQTT.fx 使用说明
下载 官网:https://softblade.de/en/download-2/ 说明:最后的免费版本是 MQTT.fx 1.7.1,官网已经没有免费的版本 下载 MQTT.fx 1.7.1 htt ...
- 成为一个合格程序员所必备的三种常见LeetCode排序算法
排序算法是一种通过特定的算法因式将一组或多组数据按照既定模式进行重新排序的方法.通过排序,我们可以得到一个新的序列,该序列遵循一定的规则并展现出一定的规律.经过排序处理后的数据可以更方便地进行筛选和计 ...
- Codeforce:131A. cAPS lOCK
原题链接 ╮(╯▽╰)╭这题题目一开始没看明白,导致wa几次.如果全是大写或者出了首字母是小写其他为大写,则转换为第一个字母大写,其他的小写 ,如果不是以上两种情况则不作处理. ╮(╯▽╰)╭水题还错 ...
- 使用 Python 参与算法竞赛
引言 众所周知,打算法竞赛最频繁使用的语言是 C++.然而,对于那些不卡复杂度的题目,可以考虑使用 Python 编写(因为 Python 真的好写). 本文将简单地介绍一些 Python 使用技巧和 ...
- 国内pip源提示“not a trusted or secure host”解决方案
大家应该都知道怎么添加国内pip源(主要是豆瓣和阿里云),~/.pip/pip.conf文件配置大概如下(下面注释掉了豆瓣源): [global] # index-url = http://pypi. ...
- InnoDB 事务加锁分析
本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/S7MhlsZveBHRSQhq5aTIJA作者:何志创 一般大家对数据库事务的了解可能停留在事 ...
- Introduction to DFT
服务器使用 登陆服务器:输入账号密码 打开terminal,保证至少一个terminal窗口是打开的 取消Linux操作系统的屏幕保护 设置Linux EDA工具配置 // 自定义环境变量设置 gvi ...
- 3. Oracle数据库异常关闭,导致错误3. Oracle数据库异常关闭,导致错误ERROR: ORA-01034: ORACLE ngt available; ORA-27101: shared memory realm does not exist
之前由于电脑没电,强制关机,导致Oracle数据库异常关闭,再次启动电脑登陆数据库时,发生以下错误: 当我尝试重新启动数据库时,发生错误: 经过查阅资料后得知:缺少INITXE.ORA文件,需要从下图 ...
- 【MMC子系统】 二、EMMC协议
[MMC子系统] 二.EMMC协议 1.前言 在上一节,我们知道EMMC.SD.SDIO三种规范都是在MMC规范之上发展而来,协议相差不大,所以Linux Kernel才能使用MMC子系统来统一管理! ...
- Pickle反序列化学习
什么是Pickle? 很简单,就是一个python的序列化模块,方便对象的传输与存储.但是pickle的灵活度很高,可以通过对opcode的编写来实现代码执行的效果,由此引发一系列的安全问题 Pick ...