深入浅出MySQL索引

news2024/12/31 6:26:07

索引

索引在MySQL中是举足轻重的。在添加索引后,我们在MySQL的查询上会极大的提高我们的查询效率,这也是慢查询解决办法之一。

数据结构

最初的时候MySQL中是采用二叉树进行插入数据的,这样的缺点很明显,就是树太高了,就如下图所示,我们需要查询5这个数据时,至少是需要比较5次才能达到效果,这个比较明显效率很低的。

二叉树

后面采用了红黑树来解决这样的问题,如下图所示。在先前的基础上确实优化了不少,减少了比较的次数,但是还是会存在树会越来越高的情况,当每一层元素放满时,就会增加层数,提高了树的高度。

红黑树

再后来MySQL就采用了B+数解决了树高度的问题,我们从B+数的数据结构来分析,这里设置Max.Degree就是树的最大高度为多少,这样就能控制树的高度,并且,你们可以发现叶子节点是完整的所有数据,并且采用了双向链表的数据结构。

B+树

 B树/B-树

这是B树也可以叫B-树,与B+树不同的是 ,B树上也降低了树的高度问题

索引分类

在了解了这些数据结构后,我们再了解MySQL有哪些不同的索引

按照以下划分MySQL中不同的索引

  • 按照数据结构分:B+树索引、Hash索引、Full-text索引
  • 按物理存储分:聚簇索引、非聚簇索引
  • 按字段特性分:主键索引、唯一索引、普通索引、前缀索引

细说索引

这样区分过后,我们在来细说MySQL中的索引

B+树索引

我们按照上述的分类来说,B+树索引是现在MySQL最常用的索引数据结构,B+树通常会在非叶子节点存储索引,在叶子节点存储数据,并且由于叶子节点上是通过双向链表来连接的,这样的查询效率非常高,正是有了指针在当中的存储,B+树就能进行范围查询,可行性很高。可以采用最少的层,管理最多的数据。

(这里补充一点)

为什么没有采用B树(B-树)

因为在B树中,是将非叶子节点的数据同时存储了索引和数据①从全局的角度而言,我们如果需要范围查询,B+树的优势就很明显,只需要遍历两个节点就可以拿到范围数据,而B树是需要逐一对比②在全文扫描中,B+树只需要扫描叶子节点即可,而B树需要遍历整个树。

Hash索引

Hash索引其实也就是采用Hash表进行存储的,通过Hash的算法,将值存储在表中,这样的优势是非常明显的,也就是精准查询的效率非常高,只要查询的是具体的值,通过Key-value,这样只需要O(1)的时间复杂度就可以查询到值,那么缺点也就明显出来了,就是无法进行范围查询。

Full-text索引

全文索引是在MySQL5.6之后才允许在InnoDB存储引擎中使用的,之前只能用于MyISAM中,并且设置的列中只能为类型是Char、Varchar、Text的类型,在全文索引中,会匹配整个单词,而不是部分单词。

非聚簇和聚簇索引区别

简单来说,聚簇索引就是基于主键索引创建的索引,其余的都称为非聚簇索引。在InnoDB中本身就是按照B+树的结果来存储所有的数据和索引,最后也只会产生一个文件,这也意味着必须是需要有主键的,但是如果没有给主键,InnoDB也会自动的生成一个隐藏列(rowID),作为自增型的主键,存储在B+树上,这也是为什么推荐使用自增型的主键,因为如果采用类型UUID的这种随机数插入,B+树的插入数据的就需要不断的变更树,使其平衡,效率也就降低了。而非聚簇索引则是将数据和索引分开的,典型的就是MyISAM存储引擎。这也就说明MyISAM的存储引擎是非聚簇的,而InnoDB是聚簇的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/672810.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++QT入门

CQT 文章目录 CQT1. QT概述1.1 什么是QT1.2 QT的发展史1.3 支持的平台1.4 QT版本1.5 Qt 的下载与安装1.6 QT的优点1.7 成功案例 2. 创建QT项目2.1 使用向导创建2.2 手动创建2.3 .pro 文件2.4 设置父对象2.5 按钮设置属性2.5.1 按钮设置文本2.5.2 设置移动2.5.3 设置固定大小 2.…

[进阶]网络通信:UDP通信,一发一收、多发多收

UDP通信 特点:无连接、不可靠通信。不事先建立连接;发送端每次把要发送的数据(限制在64KB内)、接收端1P、等信息封装成一个数据包,发出去就不管了。Java提供了一个java.net.Datagramsocket类来实现UDP通信。 Datagram…

Qt/C++使用QUiLoader动态加载ui资源文件

目录 动态对话框使用场景注意事项动态对话框加载获取动态对话框的控件对象与动态对话框建立关联动态修改ui资源文件效果测试 动态对话框 动态对话框(dynamic dialog)就是在程序运行时使用的从Qt设计师的.ui文件创建而来的那些对话框。动态对话框不需要通过uic把 .ui文件转换成…

【ARM裸机编程 | 海思SS528】- 操作 GPIO 寄存器输出低电平点亮 LED 灯

目录 一、概述二、看原理图,找LED灯的GPIO管脚三、使能 GPIO 管脚功能四、配置 GPIO 管脚为输出五、设置 GPIO 管脚输出高、低电平 一、概述 这篇文章主要介绍在 海思SS528 开发板,去操作某个 GPIO 寄存器输出高、低电平,来熄灭或点亮 LED 灯…

Spring框架中,什么是控制反转?什么是依赖注入?使用控制反转与依赖注入有什么优点

目录 一、Spring 二、控制反转 三、依赖注入 四、控制反转与依赖注入有什么优点 一、Spring Spring框架是一款开源的Java应用程序框架,它为企业级Java应用提供了全面的基础设施支持和编程模型。通过Spring框架,开发人员可以快速地搭建出高效、可维护…

C++【红黑树】

✨个人主页: 北 海 🎉所属专栏: C修行之路 🎃操作环境: Visual Studio 2019 版本 16.11.17 文章目录 🌇前言🏙️正文1、认识红黑树1.1、红黑树的定义1.2、红黑树的性质1.3、红黑树的特点 2、红黑…

chatgpt赋能python:Python中是否有局部变量?-完全解析

Python 中是否有局部变量?- 完全解析 Python 是一种高级编程语言,它因其易学、可读性强、开发速度快、功能丰富、能够快速交互、具有跨平台特性等方面而备受欢迎。其中一块关键功能是变量,变量可以存储值,以供稍后使用&#xff0…

[保姆级啰嗦教程] Tesseract OCR 5在Windows 10下编译安装及测试 (亲测成功)

作为一个优秀的文字识别(OCR)库,Tesseract最早并非开源软件,它是HP实验室在1985-1994年开发的专属软件,直到2005年,HP及内华达大学拉斯维加斯分校以开源的形式发布,然后由Google从2006年开始赞助…

[SpringBoot 分布式调度elasticjob 整合 ]

目录 🥫前言: 🥫配置作业 🥫实现任务处理类 🥫启动SpringBoot应用程序 🥬下面是代码是我另一个文章看见 记录的笔记, 我前面也使用了elastic-job做重试机制,有兴趣可以看一下 🥬依赖: 🥬…

基于MATLAB的CFAR检测仿真程序分享

基于MATLAB的CFAR检测仿真,得到平均CFAR检测。 完整程序: clc; clear; close all; warning off; addpath(genpath(pwd)); cfar phased.CFARDetector(NumTrainingCells,200,NumGuardCells,50,Method,CA); % Expected probability of False Alarm (no u…

【瑞萨RA_FSP】CTSU——电容按键检测

文章目录 一、1. 电容按键介绍二、电容按键原理三、瑞萨QE在电容按键上面的运用四、电容按键实验1. 硬件设计2. FSP配置3.复制文件4.主函数 一、1. 电容按键介绍 电容式感应触摸按键可以穿透绝缘材料外壳 8mm (玻璃、塑料等等)以上,准确无误…

OpenStack(2)--项目(租户)、用户、角色

一、项目(租户)、用户、角色的关系 重点理解项目(project/租户)、用户(user)、角色(role)三者之间的关系,首先这三者都可以单独新建,但是绑定关系是通过open…

10 分钟玩转Elastcisearch——数据可视化分析

在当今这个快速发展的科技时代,Elasticsearch 已经成为企业和开发者的重要技术工具。随着数据的爆发式增长,Elasticsearch 可以帮助个人和企业更好的理解数据、发现数据中的规律趋势和模式、并从海量数据中洞察业务价值。 为了帮助开发者能够快速上手&am…

基于SpringBoot的电子文档管理系统(源码、文档、数据库)

网上文件管理系统所用的资料库是由 SpringBoot架构所建立的 Mysql资料库。在进行设计的时候,要充分地保证了系统代码拥有良好的可读性、实用性、易扩展性、通用性、便于后期维护、操作容易、页面简洁等优势。 一、开发工具及技术介绍 (1).J…

JavaScript Day03 对象详解

文章目录 1. 什么是对象?2.对象的创建2.1 字面量模式2.2 构造函数模式 3 对象的访问4.新增删除对象中的属性5.Object显示类型转换(强制类型转换)5.1-ECMAScript中可用的3种强制类型转换如下:-Boolean(value)-String(value)-Number(value) 5.2-Object类型到Boolean类…

chatgpt赋能python:Python中的模块查找位置详解

Python中的模块查找位置详解 作为一门广受欢迎的高级编程语言,Python 拥有丰富的库和模块,这些工具让开发者能够更加高效地编写代码。但是,有时候当你在使用 Python 模块时,你可能会遇到找不到模块或者无法导入模块的错误。这时候…

【从零开始学习JAVA | 第四篇】标准的JavaBean类的构建

目录 前言: 构造方法: 构造标准JavaBean类: 对象内存图: 前言: 本片会详细的介绍JAVA中JavaBean类的手动构建,IDEA为我们提供的快捷键生成JAVA bean的方式,以及介绍一个可以快速生成…

OTT 的快速频道切换(FCC)

FCC(Fast Channel Change)快速频道切换是一种由FCC服务器下发特制的以I帧为起始的单播节目流来提升频道切换时间的方法, 通过在网络中部署FCC服务,可以回避等待I帧时间与IGMP交互时间,提升I帧传输时间,从而提高频道切换…

chatgpt赋能python:Python构造和析构:介绍和实例

Python 构造和析构:介绍和实例 当你编写 Python 程序时,你可能会注意到一个名为构造函数和析构函数的概念。这些函数可以在创建和删除一个对象时自动执行一些操作。本文将深入介绍 Python 中的构造和析构概念。 构造函数 Python 使用一种名为 __init_…

pkg打包nestjs项目问题点整理

打包运行过程中的警告 Warning Cannot include directory %1 into executable. The directory must be distributed with executable as %2. %1: node_modules\puppeteer.local-chromium %2: path-to-executable/puppeteer 解决方法: 警告大义为在路径如%1的某个目…