热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Mysql索引结构

索引含义:就是为了高效查询数据而排好序的数据机构。索引是存储在文件里的。比如对数据库的某张表的某个字段进行where查询,在没有添加索引的情况下&#x

索引含义:就是为了高效查询数据而排好序的数据机构。索引是存储在文件里的。

比如对数据库的某张表的某个字段进行where查询,在没有添加索引的情况下,是从第一行数据顺序往下查找的,比如数据是在第一百行,那么就需要对比一百行数据才能找到,如果添加索引,例如二叉树,那么理想情况下只需要对比大概六次就可以找到,效率会提高很多。

索引结构介绍:
1,二叉树
二叉树相比顺序查找更高效,它根据和父节点进行比较,判断是左侧还是右侧来查找,直到找到目标元素。但是由于建数据库时,大多会选择自增性主键,那么会造成索引值会一直添加到二叉树的右侧,从而失去二叉树的查找高效性。
2,红黑树
红黑树结构也叫平衡二叉树,它继承了二叉树的优点,而且解决了二叉树单侧递增的缺点。红黑树结构通过左旋和右旋进行自身结构调整,从而达到 左节点数<父节点数<右侧节点数。
同样红黑树也存在一个缺点,就是数据量增加,红黑树的高度会越来越大,可能会超过十几甚至二十几层,这对磁盘寻址很不利,从而导致查询效率越来越低下。
3,hash
hash结构对于精确查找可以说是非常高效的,它是通过把数据进行hash散列运算的结果作为文件指针存到索引文件中, 查找时通过文件指针可以快速定位到文件数据。
但是hash索引虽然对精准查找非常高效,但是真实环境很多都是匹配查询,hash索引无法解决范围查询。
4,B-Tree
B-Tree结构在红黑树的结构上做了优化,每个节点可以存储多个索引值,降低了树的高度,当然查询的效率也会随之提高,但是范围查找同样会从父节点开始遍历,增加许多无效遍历。
5,B+Tree
B+Tree主要针对B-Tree做了优化,为了进一步提高查询效率,和更好的范围查询,B+Tree的飞叶子节点中只存储索引值,并不存储数据,这样每个数据页(操作系统存储数据的最小单位,大概4
kb大小)就可以存储更多的索引值,增大了查询命中率,而所有的数据信息全存储在叶子节点中,同时叶子节点会有双向指针连接,当进行范围查询时,可以通过叶子节点的指针进行横向查询,避免了从父节点重新遍历,提高了查询效率。
参考链接


推荐阅读
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
    本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • qt学习(六)数据库注册用户的实现方法
    本文介绍了在qt学习中实现数据库注册用户的方法,包括登录按钮按下后出现注册页面、账号可用性判断、密码格式判断、邮箱格式判断等步骤。具体实现过程包括UI设计、数据库的创建和各个模块调用数据内容。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
author-avatar
平凡王子轶
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有