索引简单介绍
索引的本质:

- MySQL索引或者说其他关系型数据库的索引的本质就只有一句话,以空间换时间。
索引的作用:
- 索引关系型数据库为了加速对表中行数据检索的(磁盘存储的)数据结构
索引的分类
数据结构上面的分类:
- HASH 索引
- 树形索引
- 二叉树,递归二分查找法,左小右大
- 平衡二叉树,二叉树到平衡二叉树,主要原因是左旋右旋
- 缺点1,IO次数过多
- 缺点2,IO利用率不高,IO饱和度
- 多路平衡查找树(B-Tree)
- B+树
- 特点,采用左闭合的比较方式
- 根节点支节点没有数据区,只有叶子结点才包含数据区(说白了就是即便在根节点和子节点已经定位到,因为没有数据区的原因也不会停留,会一直找到叶子结点为止。)
当我们搜索13这条数据时,在根节点和子节点 都能定位,但是一直会找到叶子结点。
二叉树平衡二叉树,B树对比:
如图显示如果是自增主键情况下:
二叉树显然不适合做关系型数据库索引(和全表扫描没什么区别)。
平衡二叉树呢,虽然解决了这种情况,但是同样会导致这棵树,又瘦又高,这同样会造成上文所提到查询IO次数过多以及IO利用率不高。
B树呢,显然已经解决了这两个问题,所以下文来解释,为什么在这种情况下MySQL还用了B+树,又做了那些增强。
B树和B+树比较:
B+树在B树上面的优化:
IO效率更高(B树每个节点都会保留数据区,而B+树则不会,假设我们查询一条数据要遍历三层,那么显然B+树查询中IO消耗更小)
范围查找效率更高(如图,B+树已经形成了一个天然链表形式,只需要根据最结尾的链式结构查找)
基于索引的数据扫描效率更高。
索引类型的分类
索引类型可分为两类:
主键索引相对来说性能是最好的,但是对于SQL优化,其实大多时候我们都在辅佐索引上面做一些改进和补充。
B+树在储存引擎层面落地
- 我们创建两个表分别为
test_innodb(采用InnoDB作为储存引擎)test_myisam(采用MyISAM作为储存引擎)下图是两张表磁盘落地的相关文件,这两个储存引擎在B+树磁盘落地式截然不同的。
B+树在MyISAM落地:
- *.frm文件是表格骨架文件比如这个表中的id字段name字段是什么类型的存储在这里
- *.MYD(D=data)则储存数据
- *.MYI (I=index)则储存索引
- 比如现在执行如下sql语句 ,那么在MyISAM中他就是先在test_myisam.MYI中查找到103然后拿到0x194281这个地址然后再去test_myisam.MYD中找到这个数据返回。
SELECT id,name from test_myisam where id =103
- 如果
test_myisam表中,id为主键索引,name也是一个索引,那么在test_myisam.MYI中则会有两个平级的B+树,这也导致MyISAM引擎中主键索引和二级索引是没有主次之分的,是平级关系。因为这种机制在MyISAM引擎中,有可能使用多个索引,在InnoDB中则不会出现这种情况。
B+树在InnoDB落地:
- InnoDB不像MyISAM来独立一个MYD 文件来存储数据,它的数据直接存储在叶子结点关键字对应的数据区在这保存这一个id列所有行的详细记录。
- InnoDB 主键索引和辅助索引关系
我们现在执行如下SQL语句,他会先去找辅助索引,然后找到辅助索引下101的主键,再去回表(二次扫描)根据主键索引查询103这条数据将其返回。
SELECT id,name from test_myisam where name ='zhangsan'
这里就有一个问题了,为什么不像MyISAM在辅助索引下直接记录磁盘地址,而是要多此一举再去回表扫描主键索引,这个问题在下面相关面试题中回答,记一下这个问题是这里来的。
相关面试题
这个就不说了,上文应该讲清楚了。
这个可以总结一下,MyISAM落地数据储存会有三个类型文件 ,.frm文件是表骨架文件,.MYD(D=data)则储存数据 ,.MYI (I=index)则储存索引,MyISAM引擎中主键索引和二级索引平级关系,在MyISAM引擎中,有可能使用多个索引,InnoDB则相反,主键索引和二级索有严格的主次之分在InnoDB一条语句只能用一个索引要么不用。
可以通过执行计划来判断 可以在sql语句前explain/ desc
set global optimizer_trace='enabled=on' 打开执行计划开关他将会把每一条查询sql执行计划记录在information_schema 库中OPTIMIZER_TRACE表中
自增列,数据插入时整个索引树是只有右边在增加的,相对来说索引树的变动更小。
和上一个问题原因一样,当一个索引经常发生变化,那么就意味这,这个缩印树也要经常发生变化。4
这个原因是因为离散性,比如说,一张一百万数据的表,其中一个字段代表性别,0代表男1代表女,把这字段加了索引,那么在索引树上,将会有大量的重复数据。而我们常见的索引建立一般都是驱动型的。其目的是,尽可能的删减数据的查询范围,这个显然是不匹配的。
联合索引是一个包含了多个功效的索引,他只是一个索引而不是多个,
其次,单列索引是一种特殊的联合索引
联合索引的创立要遵循最左前置原则(最常用列>离散度>占用空间小)
通过索引项信息可直接返回所需要查询的索引列,该索引被称之为覆盖索引,说白了就是不需要做回表操作,可以从二级索引中直接取到所需数据。
索引下推,简单点来说就是,在sql执行过程中,面对where多条件过滤时,通过一个索引,完成数据搜索和过滤条件其,特点能减少io操作。
- 在InnoDB表中不可能没有主键对还是不对原因是什么?
首先这句话是对的,但是情况有三种:
- 就是在你手动显式指定这一个字段为主键时候,会以这一个字段为聚集索引。
- 在没有显式指定主键时候有两种情况:
- 他会寻找第一个UK(unique key)作为主键索引组织索引编排。
- 如果既没有指定主键也没有UK的情况下,此时会以rowId(在InnoDB表中每一个记录都会有一个隐藏(6byte)的rowId)为聚集索引。
在InnoDB 中基于辅助索引查询的内容,从辅助索引中无法直接获取,需要基于主键索引的二次扫描的操作叫做回表操作。
- 为什么在InnoDB 中辅助索引叶子结点数据区记录的是主键索引的值而不是像MyISAM中去记录磁盘地址。
这个原因其实很简单,因为主键索引的数据结构是会经常发生变化的,如果在辅助索引数据区记录磁盘地址,那么假设我们有10个辅助索引,当我们主键索引结构发生变化后,还要一个个去通知辅助索引,且主键索引结构是经常发生变化的,增删都有可能影响他的
数据结构。
到此这篇关于MySQL优化及索引解析的文章就介绍到这了,更多相关MySQL优化索引内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关推荐:
ChatGPTWindows版本:让AI助手成为你的工作与生活得力助手,Ai相减变形
ChatGPT回答是空白的背后,究竟隐藏着什么秘密?,如何用ai写作来赚钱
SEO中权重是什么意思?让你迅速网站排名的核心秘密!,长颈鹿智能AI点读机
SEO需要什么语音,seo需要考虑什么 ,学生作业ai
SEO超级,助力企业站点冲刺搜索引擎排名,白云全网营销推广哪家强
什么是SEO优化方案,seo的优化方案 ,ai emorobot
seo网站页面优化包括什么,seo页面优化技术 ,no ai写作
SEO观察:2025年搜索引擎优化的新趋势与机遇,seo2是什么状态
WPS改写-轻松提升文档创作效率的秘密武器,推广网站的优势
ChatGPT4网页空白:重新定义智能交互的未来,怎么登ai
seo适合看什么书,自学seo书籍推荐 ,ai少女 刻晴
SEO这样做,轻松引爆流量,助力企业成长,无极标准网站优化好处
seo需要干什么,seo需要具备什么知识 ,ai梦境档案世岛大宅
seo网站需要做什么,seo都需要做什么 ,ai怎么做喷漆效果
AI缩写文档:革新文档管理与自动化的未来,ai聊天中文
SEO百度优化:让你的品牌在搜索引擎中脱颖而出,日照网站推广策划
怎么用AI缩写文章,轻松提高效率的全新方法
ChatGPTO1免费:突破智能聊天的极限,体验AI无限可能,糯米ai唱歌
SEO爱站:提升网站排名,赢得流量的秘密武器,优化网站设计价格多少
SEO元素-提升网站排名的核心要素,推广分成网站有哪些
AI撰写率:让创作变得更高效,助力内容产业腾飞,人力ai
文字生成AI:开启创意写作的新纪元
用AI批量下载工具,高效管理你的文件和资源
在线AI生成文章:智能写作的未来趋势
怎么查一篇文章是不是AI写的?你需要这几个关键方法!
SEO优化需要花钱吗?从零起步,如何让SEO成为企业的“隐形财富”,字体如何往ai里面倒
为什么“蜘蛛弛查询”能成为提升网站排名的秘密武器?,惠州网站推广v1戈seo24
SEO更多-让你的企业站点在搜索引擎中脱颖而出,如何结交seo大神
ChatGPT显示无法加载网站是怎么回事?解决方法!,glow将军ai
为什么说seo这么重要,seo重要吗 ,ai19920403
什么是seo公司口碑,seo品牌 ,ai大模型训练是什么意思
“更加通顺”-让生活与工作无缝衔接的语言魅力,SEO书架书桌收纳
Chat免费,让沟通无界限,尽享智能对话时代,ai没办法置顶
GPT版本全解:从基础到高级,如何选择最适合你的方案?,韩国ai人工智能
ChatGPT网页打不开?快来看看这些解决办法,轻松恢复正常访问!,ai金色包装
打造内容创作新时代:有言AI生成助力创作者释放灵感
GPT-3.5可以免费使用吗?AI未来的无限可能,ai烧猪
AI写作免费一键生成下载,助您轻松创作!
pbootcms前端翻译插件-轻松实现网站多语言支持,拓展全球市场,st ai绘画
ChatGPT不能用?揭秘你可能忽视的真相和解决方法,强国ai2022
seo站内关键词优化,seo关键词优化经验技巧 ,ai 优点
ChatGPT网站突然不能用了?如何快速解决这个问题,让你重新畅享AI对话!,ai新建多个画板
SEO优化做什么的?揭秘SEO优化的核心价值与实战应用,ai做金色
seo需要会什么,seo要会些什么 ,ai313414919
SEO更好,让你的网站从此脱颖而出,渝中的知名网站建设
SEO能够助力网站流量增长,提升品牌竞争力,Seo网站排名原理
OpenAI银行卡扣款的公司是哪家?揭秘背后的支付流程与安全保障,AI素描相片
SEO用户:如何为您的网站带来持续流量和转化,惠州网站推广哪个好
SEO出来,打破流量瓶颈,助力企业增长的关键策略,南昌营销推广代理商电话
如何通过AI写文章,轻松提高写作效率与质量