Mysql系列-索引简介

索引是排好序数据结构

1 索引数据结构

  • hash索引、二叉树、平衡二叉树、B-Tree、B+Tree
  •  数据结构在线示例:点击跳转 

2 索引类型

2.1 聚簇索引

又叫“聚集索引” ,索引和数据存储在一起

2.2 非聚簇索引

又叫“非聚集索引” ,索引和数据分开存储

3 InnoDB存储引擎的索引

  1. 表数据文件本身是按B+Tree组织的一个索引结构文件
  2. 聚簇索引-叶节点包含完整的数据
    • 叶子节点保存全部(列)数据
    • 非叶子节点仅保存索引

3.1 设计与常见规范

3.1.1 推荐表中包含整型自增主键

建议Innodb表必须包含主键,并且推荐使用整型自增主键

  • 整型字段占用的更小的空间,可以节约磁盘;
  • 整型字段更方便进行数据比对,而字符串比较时需要逐位比较,效率相对低一些;
  • 自增是为了避免节点分裂,导致插入、更新数据性能降低;

3.1.2 推荐使用自增主键

  • 依次插入:1、3、5、7、9、10、11、12、13、14

  • 当继续插入:2、4之后,树进行了分裂,分裂效果图如下

  • 可以看出,如果是连续自增的ID,则默认会追加新的节点,不会导致节点大规模的分裂
  • 如果插入不连续的ID,会导致原先的节点分裂,影响整体的性能

3.1.3 二级索引叶子节点存储主键值

保证数据一致性,节省存储空间;

具体参考如下图的区别:图3.4 聚簇索引-主键索引、图3.4.2 非聚簇索引-联合主键

3.2 Hash索引

  • 对索引的Key进行一次hash计算就可以定位出数据存储的位置
  • 很多时候Hash索引要比B+Tree索引效率更高效
  • 仅能满足=、in,不支持范围查询
  • Hash冲突,需要额外使用链表解决

3.3 B-Tree索引

  • 叶节点具有相同的深度,叶节点的指针为空
  • 所有索引元素不重复
  • 节点中的数据索引从左到右递增排列

3.4 B+Tree(特指Mysql的B+Tree)

  • 非叶子节点不存在data,只存储索引(冗余索引),可以存放更多的索引
  • 叶节点包含所有索引字段
  • 叶子节点用双向指针链接,提高区间访问的性能
    • 普通的B+Tree的叶子结点之间仅存在单向指针,而mysql对B+Tree做了优化升级,支持双向指针,提升区间之间的数据访问效率
图3.4 聚簇索引-主键索引

3.4.1 非聚簇索引-联合主键

图3.4.1 非聚簇索引-联合主键

3.4.2 非聚簇索引-联合索引

图 3.4.2 非聚簇索引-联合索引

索引优化待完善

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux系统玩ppsspp

安装ppsspp 在ppsspp的官网,有提供Linux版本的下载链接,仔细一看是flathub的链接,也就是说ppsspp官方推荐采用flatpak安装。 确实有一些发行版提供了自己的ppsspp包,比如说openSUSE和Fedora,不过我自己试用以后发现系…

我的创作纪念日——第0x100天

官方提示今天是开始创作的第256天,最初没反应过来第256天算是个什么纪念日,好像并没什么特殊的啊。仔细一想,难道是第0x100天的意思吗?哈哈,专属于程序猿的浪漫。 既然这样,还是写一篇文章,交个…

前端使用 Konva 实现可视化设计器(22)- 绘制图形(矩形、直线、折线)

本章分享一下如何使用 Konva 绘制基础图形:矩形、直线、折线,希望大家继续关注和支持哈! 请大家动动小手,给我一个免费的 Star 吧~ 大家如果发现了 Bug,欢迎来提 Issue 哟~ github源码 gitee源码 示例地址 矩形 先上效…

实现C程序绑定TCP端口

实现C程序绑定TCP端口 步骤概述伪代码C代码实现解释在网络编程中,TCP(传输控制协议)是一种面向连接的、可靠的、基于字节流的传输层通信协议。绑定TCP端口是服务器端应用程序在网络通信中的一个关键步骤,它允许服务器监听来自客户端的连接请求。 本文将介绍如何使用C语言…

Caffenie配合Redis做两级缓存

一、什么是两级缓存 在项目中。一级缓存用Caffeine,二级缓存用Redis,查询数据时首先查本地的Caffeine缓存,没有命中再通过网络去访问Redis缓存,还是没有命中再查数据库。具体流程如下 二、简单的二级缓存实现-v1 目录结构 2…

基于SpringBoot+Vue+MySQL的房屋租赁管理系统

系统展示 用户前台界面 管理员后台界面 系统背景 二十一世纪互联网的出现,改变了几千年以来人们的生活,不仅仅是生活物资的丰富,还有精神层次的丰富。在互联网诞生之前,地域位置往往是人们思想上不可跨域的鸿沟,信息的…

uniapp 携带网址跳转webview页面报错解决

然后红框中的代码正常执行的 解决方案: 向webview页面携带参数时做以下处理: 接参后做以下处理: 效果展示:

谷歌怎么导入egd书签

https://support.google.com/chrome/answer/96816?hlzh-Hans

0906作业+思维导图梳理

一、作业: 1、创捷一个类似于qq登录的界面 1)源代码 #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);//QPushbutton:登录、退出this-…

代码随想录训练营 Day56打卡 图论part06 108. 冗余连接 109. 冗余连接II

代码随想录训练营 Day56打卡 图论part06 一、卡码108. 冗余连接 题目描述 有一个图,它是一棵树,他是拥有 n 个节点(节点编号1到n)和 n - 1 条边的连通无环无向图(其实就是一个线形图),如图&…

二、Android Studio集成ffmpeg so

目录 1、前言 2、新建AS工程 2.1 选择Native C 2.2 按图编辑和编辑 2.3 选择C标准 2.4 最初工程目录展示 3、拷贝so库到AS 4、编辑CMakeLists.txt 5、修改build.gradle 6、编辑Native-lib.cpp 7、修改MainActivity.java 8、效果展示 1、前言 本文章之前也是参考了…

HTML5中IndexedDB前端本地数据库

一、indexedDB为何替代了Web SQL Database? 跟小朋友的教育从来没有什么“赢在起跑线”这种说法一样,在前端领域,也不是哪来先出来哪个就在日后引领风骚的。 HTML5 indexedDB和Web SQL Database都是本地数据库数据存储,Web SQL Da…

DX-5009N 10G交换机 SFP接口+猫棒 代替运营商光猫 【注册状态O5但是无法PPPoe拨号踩坑——交换机VLAN配置】

买了个诺基亚 猫棒,准备代替光猫,还弱电箱一个清净 参数填完一切正常,注册状态O5 但是openwrt拨号死活上不去。windows拨号也是651 网络架构 SPF口与网口8为同一vlan,做光电转换,交给路由器wan口 路由器PPPoe拨号 1-7网…

『功能项目』播放动画时禁止点击移动【40】

我们打开上一篇39GameObject对象池 - 第三职业的项目, 本章要做的事情是在第三职业播放续航攻击动画时禁止点击时触发的移动函数,换句话说是在播放攻击动画时禁止移动 修改脚本:PlayerRayClickNavigation.cs 运行项目 - 播放第三职业续航技能…

(十四)、为 SpringCloud 项目生成 Docker 镜像

文章目录 1、原理2、最佳实践2.1、获得 SpringCloud 微服务启动模块的 jar 文件2.2、准备文件夹和 Dockerfile 文件2.3、 Dockerfile 文件的内容2.4、通过命令行构件新镜像 3、异常情况和处理:failed to create LLB definition3.1、现象3.2、解决配置国内镜像仓库清…

OpenGL——着色器画一个点

一、 绘制 在窗口中间画一个像素点&#xff1a; #include <GL/glew.h> #include <GLFW/glfw3.h> #include <iostream>using namespace std;#define numVAOs 1GLuint renderingProgram; GLuint vao[numVAOs];GLuint createShaderProgram () {const char *v…

SQL的增删改查CRUD练习知识点(day27)

1 学习目标 重点掌握插入单条记录的语法了解全表插入记录的语法重点掌握修改记录的语法重点掌握删除记录的语法重点掌握主键约束、外键约束了解检查约束、非空约束、唯一约束 2 数据类型 MySQL支持多种数据类型&#xff0c;大致可以分类三类&#xff1a;数值、日期和字符串。…

【Maven】Maven 下载安装教程(超详细)(day30)

1 学习目标 了解Spring了解SpringBoot重点掌握创建SpringBoot项目重点掌握聚合项目的创建了解Spring基于XML方法进行IOC和依赖注入了解Maven的概念重点掌握使用Maven构建项目重点掌握使用Maven进行依赖引入 2 Maven 2.1 概述 Maven是跨平台的项目管理工具。作为Apache组织中…

Python(一)-快速入门

第一个入门实例 print(hello python) 注释 #:单行注释""" """:多行注释 # 这是单行注释 # 输出一个喜欢读的课外书 print("我最喜欢读 追风筝的人")print("----------------------------")"""这是多…

Python爱心射线

系列目录 序号直达链接表白系列1Python制作一个无法拒绝的表白界面2Python满屏飘字表白代码3Python无限弹窗满屏表白代码4Python李峋同款可写字版跳动的爱心5Python流星雨代码6Python漂浮爱心代码7Python爱心光波代码8Python普通的玫瑰花代码9Python炫酷的玫瑰花代码10Python多…