MySQL优化及索引的方法

索引简单介绍

索引的本质:

MySQL索引或者说其他关系型数据库的索引的本质就只有一句话,以空间换时间。

索引的作用:

索引关系型数据库为了加速对表中行数据检索的(磁盘存储的)数据结构

索引的分类

数据结构上面的分类:

HASH 索引

等值匹配效率高

不支持范围查找

树形索引

二叉树,递归二分查找法,左小右大

平衡二叉树,二叉树到平衡二叉树,主要原因是左旋右旋

缺点1,IO次数过多

缺点2,IO利用率不高,IO饱和度

多路平衡查找树(B-Tree)

特点,大大的减少了树的高度

B+树

特点,采用左闭合的比较方式

根节点支节点没有数据区,只有叶子结点才包含数据区(说白了就是即便在根节点和子节点已经定位到,因为没有数据区的原因也不会停留,会一直找到叶子结点为止。)

当我们搜索13这条数据时,在根节点和子节点 都能定位,但是一直会找到叶子结点。

MySQL优化及索引的方法

二叉树平衡二叉树,B树对比:

如图显示如果是自增主键情况下:二叉树显然不适合做关系型数据库索引(和全表扫描没什么%ignore_a_1%)。平衡二叉树呢,虽然解决了这种情况,但是同样会导致这棵树,又瘦又高,这同样会造成上文所提到查询IO次数过多以及IO利用率不高。B树呢,显然已经解决了这两个问题,所以下文来解释,为什么在这种情况下MySQL还用了B+树,又做了那些增强。

MySQL优化及索引的方法

B树和B+树比较:

MySQL优化及索引的方法

B+树在B树上面的优化:

IO效率更高(B树每个节点都会保留数据区,而B+树则不会,假设我们查询一条数据要遍历三层,那么显然B+树查询中IO消耗更小)

范围查找效率更高(如图,B+树已经形成了一个天然链表形式,只需要根据最结尾的链式结构查找)

MySQL优化及索引的方法

基于索引的数据扫描效率更高。

索引类型的分类

索引类型可分为两类:

主键索引

辅佐索引(二级索引)

唯一性索引

复合索引

普通索引

覆盖索引

虽然主键索引性能相对最佳,但通常在SQL优化中,我们会在辅助索引上进行改进和补充。

B+树在储存引擎层面落地

我们创建两个表分别为test_innodb(采用InnoDB作为储存引擎)test_myisam(采用MyISAM作为储存引擎)下图是两张表磁盘落地的相关文件,这两个储存引擎在B+树磁盘落地式截然不同的。

MySQL优化及索引的方法

B+树在MyISAM落地:

*.frm文件是表格骨架文件比如这个表中的id字段name字段是什么类型的存储在这里

*.MYD(D=data)则储存数据

*.MYI (I=index)则储存索引

MySQL优化及索引的方法

比如现在执行如下sql语句 ,那么在MyISAM中他就是先在test_myisam.MYI中查找到103然后拿到0x194281这个地址然后再去test_myisam.MYD中找到这个数据返回。

SELECT id,name from test_myisam where id =103

MySQL优化及索引的方法

如果test_myisam表中,id为主键索引,name也是一个索引,那么在test_myisam.MYI中则会有两个平级的B+树,这也导致MyISAM引擎中主键索引和二级索引是没有主次之分的,是平级关系。因为这种机制在MyISAM引擎中,有可能使用多个索引,在InnoDB中则不会出现这种情况。

B+树在InnoDB落地:

MySQL优化及索引的方法

MySQL优化及索引的方法

InnoDB不像MyISAM来独立一个MYD 文件来存储数据,它的数据直接存储在叶子结点关键字对应的数据区在这保存这一个id列所有行的详细记录。

InnoDB 主键索引和辅助索引关系

我们现在执行如下SQL语句,他会先去找辅助索引,然后找到辅助索引下101的主键,再去回表(二次扫描)根据主键索引查询103这条数据将其返回。

SELECT id,name from test_myisam where name ='zhangsan'

这里就有一个问题了,为什么不像MyISAM在辅助索引下直接记录磁盘地址,而是要多此一举再去回表扫描主键索引,这个问题在下面相关面试题中回答,记一下这个问题是这里来的。

MySQL优化及索引的方法

相关面试题

为什么MySQL选择B+树作为索引结构

这个就不说了,上文应该讲清楚了。

B+树在MyISAM和InnoDB落地区别。

这个可以总结一下,MyISAM落地数据储存会有三个类型文件 ,.frm文件是表骨架文件,.MYD(D=data)则储存数据 ,.MYI (I=index)则储存索引,MyISAM引擎中主键索引和二级索引平级关系,在MyISAM引擎中,有可能使用多个索引,InnoDB则相反,主键索引和二级索有严格的主次之分在InnoDB一条语句只能用一个索引要么不用。

如何判断一条sql语句是否使用了索引。

可以通过执行计划来判断 可以在sql语句前explain/ desc

set global optimizer_trace=’enabled=on’ 打开执行计划开关他将会把每一条查询sql执行计划记录在information_schema 库中OPTIMIZER_TRACE表中

为什么主键索引最好选择自增列?

自增列,数据插入时整个索引树是只有右边在增加的,相对来说索引树的变动更小。

为什么经常变动的列不建议使用索引?

和上一个问题原因一样,当一个索引经常发生变化,那么就意味这,这个缩印树也要经常发生变化。4

为什么说重复度高的列,不建议建立索引?

这个原因是因为离散性,比如说,一张一百万数据的表,其中一个字段代表性别,0代表男1代表女,把这字段加了索引,那么在索引树上,将会有大量的重复数据。而我们常见的索引建立一般都是驱动型的。其目的是,尽可能的删减数据的查询范围,这个显然是不匹配的。

什么是联合索引

联合索引是一个包含了多个功效的索引,他只是一个索引而不是多个,

其次,单列索引是一种特殊的联合索引

联合索引的创立要遵循最左前置原则(最常用列>离散度>占用空间小)

什么是覆盖索引

通过索引项信息可直接返回所需要查询的索引列,该索引被称之为覆盖索引,说白了就是不需要做回表操作,可以从二级索引中直接取到所需数据。

什么是ICP机制

索引下推,简单点来说就是,在sql执行过程中,面对where多条件过滤时,通过一个索引,完成数据搜索和过滤条件其,特点能减少io操作。

在InnoDB表中不可能没有主键对还是不对原因是什么?

首先这句话是对的,但是情况有三种:

就是在你手动显式指定这一个字段为主键时候,会以这一个字段为聚集索引。

在没有显式指定主键时候有两种情况:

他会寻找第一个UK(unique key)作为主键索引组织索引编排。

如果既没有指定主键也没有UK的情况下,此时会以rowId(在InnoDB表中每一个记录都会有一个隐藏(6byte)的rowId)为聚集索引。

什么是回表操作

在InnoDB 中基于辅助索引查询的内容,从辅助索引中无法直接获取,需要基于主键索引的二次扫描的操作叫做回表操作。

为什么在InnoDB 中辅助索引叶子结点数据区记录的是主键索引的值而不是像MyISAM中去记录磁盘地址。

这个原因其实很简单,因为主键索引的数据结构是会经常发生变化的,如果在辅助索引数据区记录磁盘地址,那么假设我们有10个辅助索引,当我们主键索引结构发生变化后,还要一个个去通知辅助索引,且主键索引结构是经常发生变化的,增删都有可能影响他的
数据结构。

以上就是MySQL优化及索引的方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/147886.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 17:47:34
下一篇 2025年12月2日 17:47:45

相关推荐

  • FET令牌,回购计划和ASI联盟:分散AI的新时代?

    探索fet代币、5000万美元回购计划以及人工超级智能联盟(asi)的最新动态,这些进展预示着去中心化ai未来的强劲发展。 FET代币、回购行动与ASI联盟:开启去中心化AI新时代? 当前,“FET代币、回购计划、ASI联盟”正引发广泛关注,标志着去中心化人工智能及其现实应用场景的重要突破。 ASI…

    2025年12月8日
    000
  • BlockDag:预售成功和1美元的梦想 – 分析增长潜力

    blockdag凭借其3.135亿美元的强劲预售、庞大的社区基础以及前沿技术,展现出巨大的上升空间。它真的能触及1美元的价格吗?我们一起来探讨。 BlockDag:预售火爆与1美元目标 —— 探究增长动能 Blockdag正掀起热潮,成为加密圈热议的话题。在完成一轮极具吸引力的预售之后,人们不禁发问…

    2025年12月8日
    000
  • 重点重点的加密资产:解码Polkadot,Dogecoin和AI Revolution

    深入探讨加密资产的动态,聚焦polkadot可能的突破机会、dogecoin的关键支撑位以及ai在加密投资领域的颠覆性潜力。 核心关注的加密项目:解析Polkadot、Dogecoin与AI革新 加密市场始终是创新与波动交织的舞台。本文将聚焦Polkadot、Dogecoin及人工智能对数字资产投资…

    2025年12月8日
    000
  • XRP ETF动量:Teucrium的AUM增长信号信号看涨未来

    xrp etf批准前景显著升温,teucrium推出的2倍杠杆xrp etf已吸纳1.22亿美元资产管理规模,向华尔街释放出强烈的机构关注度信号。 XRP ETF势头强劲:Teucrium AUM跃升预示积极前景 围绕潜在XRP ETF的讨论愈发热烈,Teucrium推出的两倍杠杆XRP ETF(X…

    2025年12月8日
    000
  • XRP价格,波纹和中央银行:解码连接

    探索ripple与中央银行之间的合作关系及其对xrp价格的潜在影响,揭示cbdc整合背后的炒作与现实。 在XRP、Ripple与中央银行交织的世界中,充满了各种猜测。Ripple与各国央行日益加深的合作是否能推动XRP价格上涨?我们来深入探讨这一核心问题。 Ripple在中央银行中的布局 Rippl…

    2025年12月8日
    000
  • Web3时代的加密投资:恒星,Kaspa和新兴趋势的聚光灯

    探索加密投资不断演变的格局,重点关注web3、stellar(xlm)、kaspa(kas)以及meta earth等创新平台,揭示其中的关键趋势与潜在机遇。 Web3时代的加密投资:恒星、Kaspa与新兴趋势聚焦 深入“加密投资、Web3、Stellar Kaspa”这一领域,必须理解那些正在重塑…

    2025年12月8日
    000
  • Ozak AI:在加密大海的模因中明智的赌注?价格预测与分析

    ozak ai能否超越如pepe这类模因币?本文分析了ozak ai在ai驱动的加密领域的发展潜力、价格预测及其独特优势。 加密市场总是充满变数,对吧?前一刻,佩佩币暴涨,下一刻,人们又开始追逐新的热点。然而,在这场模因币热潮中,有些项目正在努力打造真正的价值。我们一起来看看Ozak AI及其在AI…

    2025年12月8日
    000
  • XRP,Ozak AI和加密投资:导航2025年景观

    在加密投资领域,xrp与ozak ai正成为关注的焦点。ozak ai将人工智能与区块链技术结合,展现出巨大的增长潜力。 XRP、Ozak AI与加密投资:洞察2025年市场格局 加密货币世界持续热闹非凡,XRP和Ozak AI近期频繁占据头条。XRP以其经典魅力吸引投资者,而Ozak AI则凭借强…

    2025年12月8日
    000
  • Dogecoin,Shiba Inu和Meme Coin Mania:下一步是什么?

    dogecoin和shiba inu还值得继续关注吗?深入了解这些模因币的最新动向、面临的挑战以及未来潜力。 Dogecoin、Shiba Inu与Meme Coin热潮:接下来会发生什么? 曾经风靡加密世界的Dogecoin和Shiba Inu等模因币,如今是否还能维持热度?在市场逐渐收紧的情况下…

    2025年12月8日
    000
  • 玛丽埃塔(Marietta)数字化:停车收费表的未来就在这里!

    宾夕法尼亚州玛丽埃塔(marietta)正在告别老旧的宿舍式停车系统,全面引入数字化支付方式。了解这一转变对居民和游客带来的影响。 玛丽埃塔迈向数字化:迎接智能停车新时代! 向翻找零钱的日子说再见吧!宾夕法尼亚州玛丽埃塔(Marietta)对其停车设施进行重大升级,将传统硬币驱动的设备替换为现代化的…

    2025年12月8日
    000
  • 社交,产量和经济范式转变:Pop Max是否领导了指控?

    探索pop max等社交平台如何融合分散金融与社区,将用户行为转化为有形资产,并重塑经济范式。 社交、产量与经济范式的变革:Pop Max是否引领潮流? 在不断演进的Web3领域中,社交互动与去中心化金融的结合正在开辟令人振奋的新可能。诸如Pop Max之类的平台正站在这一浪潮的最前沿,致力于重新定…

    2025年12月8日
    000
  • 比特币的价格下降:在动荡的市场中导航关键支持水平

    比特币近期的价格起伏令投资者聚焦于关键支撑位。这会是大幅下挫的前兆,还是这些支撑位能稳如磐石? 比特币价格下滑:动荡市况下的核心支撑观察 比特币正经历剧烈波动,市场目光聚焦在几个关键的支撑点上。这次下跌是暂时回调,还是趋势反转?我们来一探究竟。 比特币的关键支撑区域 目前市场普遍关注的支撑区间位于9…

    2025年12月8日
    000
  • Stablecoin,创新和加密未来:纽约的观点

    探索stablecoins不断演化的版图,了解加密货币市场最新的进展,以及这一切对金融未来的影响。 Stablecoins正在重塑支付方式,加密市场也日趋成熟。这将如何影响未来?让我们以纽约风格一探究竟。 Stablecoins崛起:更迅速、更经济、更可靠 USDC等Stablecoins正掀起一股…

    2025年12月8日
    000
  • 区块链,P2P游戏和市场:链上经济体的新时代

    探索区块链技术与p2p游戏及市场的融合。了解optake和opensea等平台如何推动数字资产交易及链上经济的未来。 区块链、点对点(P2P)游戏以及在线市场的交汇正在催生一系列新机遇。稳定币支付方式和NFT交易平台的发展,正推动更加安全、高效且用户友好的数字经济生态建设。 超越:在区块链上重塑P2…

    2025年12月8日
    000
  • 加密公牛奔跑手表:2025年6月注视着Altcoins

    在2025年6月探索加密货币领域?了解有潜力的山寨币,如sky、pendle和mixie,以及xrp的价格波动和solaxy预售的成功背后的观点。 2025年6月正逐渐成为加密货币市场中一个引人注目的月份,特别是对Altcoins而言。随着潜在牛市信号的出现,现在是时候深入研究哪些山寨币吸引了关注,…

    2025年12月8日
    000
  • 空调警报:Infofi,预测性AI和Crypto入职的未来

    kucoin上线infofi代币,将预测性人工智能推向加密领域的核心位置,而无摩擦的空投机制正重新定义用户体验。 空投新风向:Infofi与预测AI引领未来趋势 当各类项目不断尝试吸引用户并构建活跃社区时加密行业正掀起新一轮热潮。当前最引人注目的趋势之一是将空投机制与预测性人工智能相结合。Kucoi…

    2025年12月8日
    000
  • 福特和卡尔达诺:用区块链彻底改变法律数据存储

    福特深入研究cardano区块链的安全机制,结合ai驱动的法律数据管理方案,或将为受监管行业树立新标杆。 福特与Cardano:区块链重塑法律数据存储方式 在数据安全与合规性愈发重要的当下,福特联合Iagon和云法院,探索利用Cardano区块链进行法律数据管理,迈出了关键一步。该项目旨在解决传统法…

    2025年12月8日
    000
  • Memeland Summit,Web3,迪拜合作:不仅仅是模因吗?

    深入探索迪拜的memeland峰会,探索其web3合作、meme文化融合以及对数字资产格局的未来影响。 Memeland Summit,Web3,迪拜合作:仅仅是模因吗? 迪拜举办的Memeland峰会已圆满落幕,为人们带来了关于Web3和Meme文化发展的深刻洞见。它不仅呈现了丰富的合作形式,也预…

    2025年12月8日
    000
  • 币圈交易所前三名(最新版)

    币安、欧易、火币均为主流交易所,各有特点。1. 币安以技术实力强、产品线丰富著称,支持多种交易方式,手续费约0.1%,安全性高,适合新手;2. 欧易提供多样交易产品及专业分析工具,手续费0.08%-0.1%,适合有经验者;3. 火币以本地化服务见长,手续费约0.2%,界面简洁,适合新手。选择时应结合…

    2025年12月8日
    000
  • 2025新手必看:十大易用加密货币交易平台

    对于2025年的加密货币新手来说,选择一个易用且可靠的交易平台是踏入数字资产世界的关键第一步。市面上的交易平台琳琅满目,但并非所有平台都适合新手。易用性、用户界面友好程度、交易费用、客户支持以及安全性都是需要重点考量的因素。本文将深入剖析十大易用加密货币交易平台,旨在帮助新手用户快速上手,避免踩坑,…

    2025年12月8日 好文分享
    000

发表回复

登录后才能评论
关注微信