索引会自动更新吗_mysql的B+树中数据存放结构和索引常见问题你会吗?

问题

  1. 如何理解mysql中 数据存放在`B+树`的叶子节点而不是其他非叶子节点?
  2. (InnoDB中)B+树的叶子节点一定存放全部的真实数据吗?辅助索引和聚集索引的B+树有什么区别?联合索引的B+树中数据又有啥区别呢?
  3. MyISAM中的索引是什么样的?
319c96aa3401a2b4c1bc2cc01091e2f1.png

解答问题一

快速理解

你可以把mysql中存放的数据比作一本书的目录,然后这个目录中有大标题,小标题,大目录,小目录,目录的最下面就是具体文章的页数(InnoDB中最下面就是真实的数据)。

详解

首先B+树的叶子节点我们已经知道了存放的是真实数据,那么其他节点呢?叶子节点的父节点存放的是什么?最简单的回答就是:存放的是目录 ,这个目录有点特殊,首先举例来说:假如有三层树,最底层就是存放的数据,第二层存放的是这条数据的 页号和最小主键值,这个组合就是一条新的数据,称为目录项记录,很多条这种数据记录着底层数据的主键和页号信息,查找的时候可以通过最先通过记录目录项数据页定位真实数据存放在哪个数据页(InnoDB最小单位按页来的,大小16KB),那第一层呢?第一层和第二层一样,同样存放的是第二层目录项记录的页号和该页下面的最小主键值,即数据页中记录的类型都一样,但是主键范围更广了。

总结补充

用户记录和目录项记录存放的地方都是一样的,都在基本单元数据页里面,但是记录类型有差别的,在每条记录的头信息中有个叫record_type字段,每一种代表不同的类型
sql 0:普通的用户记录 1:目录项记录 2:最小记录 3:最大记录 用上面这种储存结构,熟悉二分法的我们很清楚,数据从小到大排列,每页跨度逐渐减小,这不就是二分法的优势吗?快速定位某一页,再从页定位到真实记录,这就是强大之处。

问题二解答

B+树中叶子节点存放的真实数据没错,但是每一棵树并不是存放的是全部真实数据,这里就牵扯到了聚集索引和辅助索引,聚集索引不需要人为的去主动创建,你可以把上面提到的数据真实存放目录当作聚集索引,一开始的时候就安排好了,数据就是按照这个目录存放的。


辅助索引就不一样了,我们随机选取了某一列作为索引,那么InnoDB会新创建一棵B+树,数据存放的格式和前面提到的一样,只不过排序的不是主键,而是你选取的这一页,底层叶子节点中你选取的列+主键,当你使用这个索引的时候首先查询到的是这个数据的主键,然后再去回表检索完整数据,需要注意的是,因为这些列的值可能是相同的,所以目录项记录的时候无法区分,所以和聚集索引有区别的是,辅助索引的目录项记录不仅包含页号和列值,还有一个主键值


联合索引中B+树叶子节点中数据排序方式就是按照你创建索引的那几个列来的,第一列相同,则按照第二列,依次向后比对。而叶子节点的数据则包含你创建索引的几个列和主键值,同样检索其他列数据需要回表操作。

问题三解答

首先要明确的是,MyISAM中数据和索引是分离的,数据是数据,索引是索引分开储存,通过索引行号定位数据的地址偏移量,然后回表迅速定位数据。所以如果要按照聚集索引的标准来说,那么MyISAM创建的索引均属于二级索引。

#程序员##MySQL##索引#

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

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

相关文章

java8 按条件过滤集合

//黄色部分为过滤条件list.stream().filter(user-> user.getId() > 5 && "1组".equals(user.group)).collect(Collectors.toList()); 示例: public class HelloWorld {public static void main(String[] args) {Random random new Random(…

pandas-事例练习

补充:  DataFrame.dropna(axis0, howany, threshNone, subsetNone, inplaceFalse)功能:根据各标签的值中是否存在缺失数据对轴标签进行过滤,可通过阈值调节对缺失值的容忍度参数:axis : {0 or ‘index’, 1 or ‘columns’},或 …

wex5链接mysql_wex5数据库连接自己的数据库在哪里配置的

十二月 19, 2015 8:20:46 下午 org.apache.catalina.core.StandardWrapperValve invoke严重: Servlet.service() for servlet X5 Baas Takeout Servlet threw exceptionjava.sql.SQLException: Access denied for user rootlocalhost (using password: YES)at com.mysql.jdbc.M…

扒一扒TCP协议与UDP协议

TCP服务的特点 (1)面向连接:使用TCP协议通讯的双方必须先建立连接,然后才能开始数据的读写。双方都必须为该连接分配必要的内核资源,以管理连接的状态和连接上数据的传输。TCP链接是全双工的,即双方的数据读…

linux 查看共享磁盘_如何可视化地查看 Linux 系统磁盘使用情况?

本文介绍一个可视化地查看 Linux 系统磁盘使用情况的工具——Duc。Duc 是一个工具集,可以在类 Unix 操作系统上建立索引、检查和可视化系统的磁盘。与其它相似工具相比,它可以正常工作在超大规模的文件系统上。测试表明,Duc 可以毫无问题地工…

IP 、127.0.0.1、localhost 三者区别

一、Ping命令 1、Ping命令,用来检查两台物理机间的TCP/IP网络是否通畅或者网络连接速度,是TCP/IP协议的一部分。 2、PING (Packet Internet Groper),因特网包探索器,IP层协议通过机器B的IP地址和自己的子网掩码,判断它…

mysql git下载安装_xshell、python、git、mysql安装(玩阿里云的第二天)

2、因为放弃了图形化桌面,所以要找清自己的位置。不清楚自己刚进去时在哪个目录,先ll、ls、cd ..试试3、python安装安装python失败,同时发现自带了2个python版本(python2.7和python3.6);卸载python:sudo apt-get remov…

Tomcat端口冲突

在编码时&#xff0c;有时候会一步小心多开了一个tomcat&#xff0c;而且端口也没改&#xff0c;这个时候就会造成端口冲突问题&#xff1a; 解决冲突问题也很简单&#xff1a;打开 dos窗口&#xff1a;netstat -ano|findstr <端口号> 输入netstat -ano|findstr 加上被冲…

vscode html 格式化_详解VSCode 格式化不符合预期的问题

一句话总结不同格式化程序执行时长不一样&#xff0c;导致文件格式好后和预期不符。请务必保持校验&#xff08;Lint&#xff09;规则和格式化&#xff08;Format&#xff09;规则一致&#xff0c;不然格式化后还是不符合预期是非常讨厌的。本篇主要讲解怎么调教VSCode的保存时…

反斜杠转义mysql java_mysql数据库中的反斜杠”\“怎么使用Java进行转义

mysql数据库中的反斜杠”\“怎么使用Java进行转义发布时间&#xff1a;2020-11-24 15:15:12来源&#xff1a;亿速云阅读&#xff1a;88作者&#xff1a;Leah这期内容当中小编将会给大家带来有关mysql数据库中的反斜杠”\“怎么使用Java进行转义&#xff0c;文章内容丰富且以专业…

C#总结(四)调用C++动态库

由于公司很多底层的SDK&#xff0c;都是C开发&#xff0c;上层的应用软件却是C# Winform程序。在实际工作的过程中&#xff0c;就经常碰到了C# 程序调用C 动态库的问题。最近一直在和C 打交道&#xff0c;C# 怎么调用C 类库函数。也遇到了一些问题&#xff0c;所以就来总结总结…

mysql外码内码定义_中文编码杂谈(转) - CodeAxe的个人页面 - OSCHINA - 中文开源技术交流社区...

编码问题的例子在windows自带的notepad(记事本)程序中输入“联通”两个字&#xff0c;保存后再次打开&#xff0c;会发现“联通”不见了&#xff0c;代之以“&#xfffd;&#xfffd;ͨ”的乱码。这是windows平台上典型的中文编码问题。即文件保存的时候是按照ANSI编码(其实就…

洛谷1417烹调方案——动态规划:价值受时间影响

题目&#xff1a;https://www.luogu.org/problemnew/show/P1417 与01背包的不同在于价值受时间影响。 对第i个物品的遍历有一个先后顺序&#xff0c;在01背包里顺序不影响&#xff0c;但此时顺序会影响。 所以可以考虑对遍历的顺序排序。因为排序时会把每一个都和其余所有比较一…

python re.split_python re模块re.split将字符串分割后返回列表

re.splitsplit 方法按照能够匹配的子串将字符串分割后返回列表&#xff0c;它的使用形式如下&#xff1a;re.split(pattern, string[, maxsplit0, flags0])参数&#xff1a;参数描述pattern匹配的正则表达式string要匹配的字符串。maxsplit分隔次数&#xff0c;maxsplit1 分隔一…

python自动化控制设备有限公司_华为 Python网络自动化

哈喽&#xff0c;大家好&#xff01;我是艺博东 &#xff0c;是一个思科出身、专注于华为的网工&#xff1b;好了&#xff0c;话不多说&#xff0c;我们直接进入正题。光棍二十年&#xff0c;不知道情人节是什么鬼东西。还是好好学技术吧&#xff01;努力、奋斗吧&#xff01;为…

vue组件 Prop传递数据

组件实例的作用域是孤立的。这意味着不能(也不应该)在子组件的模板内直接引用父组件的数据。要让子组件使用父组件的数据&#xff0c;我们需要通过子组件的props选项。 prop 是单向绑定的&#xff1a;当父组件的属性变化时&#xff0c;将传导给子组件&#xff0c;但是不会反过来…

Study之2 Glance相关操作-devstack

1&#xff0c;Glance的image是存储在backend中&#xff0c;backend配置在&#xff1a; /etc/glance/glance-api.conf。2, devstack默认&#xff1a;image 存放在控制节点本地目录 /opt/stack/data/glance/images/ 中。 3&#xff0c;查看目前已经存在的image。 source devstack…

python视图函数是什么意思_Flask初学者:视图函数

视图函数返回html模板&#xff1a;使用“from flask import render_template”&#xff0c;在函数中传入相对于文件夹“templates”html模板路径名称字符串即可&#xff0c;flask会自动到项目根目录的“templates”文件夹(创建flask项目时&#xff0c;pycharm会自动创建两个空文…

kendo Grid json解析的问题

新建立了一个 页面&#xff0c;在grid中使用了dropdownlist&#xff0c;总是显示companyId is not defined &#xff0c;以前这个问题解决过了&#xff0c;忘记记录了额&#xff0c;现在不知道怎么办了 下面的这个解决方法是错误的razor语法中的renderScript移动到scrip前面去解…

人工蜂群算法python_教程 | 用人工蜂群算法求解k-分区聚类问题

原标题&#xff1a;教程 | 用人工蜂群算法求解k-分区聚类问题选自towarddatascience作者&#xff1a;Pedro Buarque参与&#xff1a;Pedro、刘晓坤群体智能算法是一类受生物群体智能行为的启发而发展出来的算法&#xff0c;社会性动物例如蚂蚁、蜜蜂、鱼等&#xff0c;个体的简…