深入理解mysql索引底层数据结构及算法

萨瓦迪卡2个月前 (08-15)MySql323

一、索引的本质:帮助Mysql 高效获取数据的排好序数据结构

二、索引数据结构:二叉树、红黑树、Hash表、 B-Tree

      二叉树:不适合递增的列。(链表式,查找次数多。右边比左边大)

      红黑树:本质是二叉树,二叉平衡树(比二叉树优化了点)

      Hash表(基本不用):hash算法,MD5基于此,仅能满足=,in,不支持范围查询。

      B-Tree: 

    • 叶节点具有相同的深度,叶节点的指针为空    

    • 所有索引元素不重复

    • 节点中的数据索引从左到右递增排列


三、mysql使用的索引的数据机构是: B+Tree

baf8d1bc-9669-43a9-a8d3-7aad74d4e4a8.png

 B-Tree与 B+Tree的区别:

1.非叶子节点不存储data,只存储索引(冗余),可以放更多的索引。tree结构从左到右依次递增

2.叶子节点包含所有的索引字段。

3.B+Tree叶子节点有双向指针,方便范围查找。


四.表的存储引擎索引:

MylSAMl存储引擎索引也是存到磁盘上的,一般在mysql的安装文件data里面。索引和数据是分开的,通过索引对应的磁盘文件地址,再通过磁盘文件地址找完整的数据 。

innoDB存储引擎

聚集索引:叶子节点索引下面存的是完整数据。(文件在ibd文件中)

39c61701-f3da-4766-bda2-bc197e56d48f.png


建议innoDB表要建主键,并使用整型。容易比大小,字符串还得逐个比对。

聚集索引和非聚集索引(还需要回表)那个更快?聚集更快。

如果用分库分表,用 雪花算法比较好。

五、联合索引:遵循最左前缀原则。



本文原创,转载必追究版权。

分享给朋友:

相关文章

揭秘!如何用一句话找到你的一万微友

 玩微商一年半的时间了,现在的微商如火如荼,很多刚进入微商行业的伙伴都在烦恼一个问题,那就是粉丝、粉丝,我最近调查了身边30多个微友,有25个竟然都是好友问题,有的竟然给我说主动加了50多个...

js限制input只能输入数字、英文、汉字

 1.只能输入数字和英文的:  <input onkeyup="value=value.replace(/[\W]/g,'') "...

get/post方式调用http接口

get/post方式调用http接口

 1. 项目环境如下:myeclipse8.5 、tomcat5.0/weblogic、xp、JDK:开发1.5,编译1.4为了方便,在原来的web项目UpDown中新建了一个httpcal...

js/jquery 日历控件及实例下载

js/jquery 日历控件及实例下载

实现日历控件效果:页面:<link href="${base}/resource/${profile.path}/css/lhgcalendar.css" rel="...

MyEclipse10.7注册码生成

注意经验里的工具可能不可用,请点击 生成注册码工具  下载。提取码:p1w4MyEclipse10.7注册码激活步骤:点击下面的链接http://jingyan.baidu.com/arti...

js/jquery 实现点击图片更换头像(图片)实例

    总之一句话, 可以先将 file类型 的input 隐藏 起来,通过 图片(头像)的onclick事件 来触发 file 的onclick事件。1.引入外部js:...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。