您当前的位置:首页 > 电脑百科 > 数据库 > 百科

数据库:innodb数据组织形式

时间:2020-09-09 14:06:18  来源:  作者:

MySQL数据库的innodb存储引擎中,数据是按照主键以B+树的形式存储的。如果在建表的时候没有指定主键,那么引擎会自动添加一列主键。

数据库:innodb数据组织形式

B+树

B+树是一种平衡树,即根节点到各个叶子节点的高度不超过1。在B+树中,所有记录节点都是按照键值的大小顺序存在同一层的叶子节点上,由各个叶子节点指针进行链接。B+的形式如上图所示。从上图中,如果用户从最左边的叶子节点遍历即可得到所有键值的顺序排序:4、7、10、15、25、36、50、59、61、65、75、80、85、90。

平时我们常接触的查找结构是平衡二叉树或者红黑树。为什么innodb存储引擎选择了B+树呢?首先我们知道innodb的数据存储磁盘上。由于磁盘IO相对于CPU和内存而言要慢很多,所以减少磁盘IO是提升性能的关键,另外对于机械磁盘而言顺序读取要比随机读取的性能高出1到2个数量级。我们来看上图中的例子,在查找时,可以先将根节点一次读入内存,再进行二分法查找,定位到叶子节点的位置之后,也可以一次将叶子节点加载到内存在进行查找。这样基本上只需要2次IO就能找到数据了。对于平衡二叉树或者红黑树就需要更多次的IO,并且这些IO都是离散读,性能较差。

innodb的主键又被称为聚集索引。通过聚集索引可以直接查找到整条记录(因为B+树的叶子节点就是数据节点,存储了数据)。innodb还有一种辅助索引。这是一个二级索引。它也是B+树组织的,但是叶子节点上的数据,不是数据,而是聚集索引。一个辅助索引的查找的大概过程是:在辅助索引上找到聚集索引,再通过聚集索引找到数据。可以看出相对于聚集索引,辅助索引的查找过程更长,所以一般innodb更倾向于使用聚集索引。但是也有些情况下,查找是搜索辅助索引就能完成。比如:一张表:t(a,b,c),其中a是主键,b是辅助索引,对于select b from t where b > 10或者select count(*) from t where b > 10都是不需要再查找聚集索引的。

我们上面提到了磁盘的顺序读的性能要明显高于随机读。我们再来看辅助索引的查找过程。辅助索引也是B+树组织的,叶子节点是按照辅助索引的值来排序的。这就导致了,如果我们按照辅助索引的顺序去聚集索引查找时,是随机读。innodb为了提升性能,有一种优化,对于辅助索引的范围查找,先找出这些聚集索引,再按照聚集索引进行排序,按照这个顺序去聚集索引中查找,这样可以尽量保证顺序读,并且可以充分利用缓存。



Tags:innodb   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
如果你使用过mysql数据库,对它的存储引擎:innodb,一定不会感到陌生。众所周知,在mysql8以前,默认的存储引擎是:myslam。但mysql8之后,默认的存储引擎已经变成了:innodb,它是我们建表...【详细内容】
2021-09-17  Tags: innodb  点击:(48)  评论:(0)  加入收藏
在InnoDB存储引擎的索引里,存在一些数据存储结构的概念,这一节先了解一下InnodDB的逻辑存储结构,为索引的学习打好基础。从InnoDB存储引擎的存储结构看,所有数据都被逻辑地放在...【详细内容】
2021-04-21  Tags: innodb  点击:(188)  评论:(0)  加入收藏
以下文章来源于苦味代码 ,作者L虽然我们习惯于给主键ID指定AUTO_INCREMENT属性,但是AUTO_INCREMENT也是可以指定到非主键字段的,唯一的约束就是这个字段上面得加索引,有了索引,就...【详细内容】
2021-03-03  Tags: innodb  点击:(209)  评论:(0)  加入收藏
很多同学在面试中会被问到数据库的问题,而常被问到的一个问题就是:MySQL 中的 InnoDB 和 MyISAM 之间是什么关系,分别有什么特点?许多同学都把 MySQL 作为自己的数据库,但是可能...【详细内容】
2020-12-08  Tags: innodb  点击:(130)  评论:(0)  加入收藏
总结下之前看到的一些关于MySQL索引原理的内容,好记性不如烂笔头。1. B+树我们知道InnoDB的索引是以B+树的形式组织的。B+树是一种树数据结构,是一个n叉树,每个节点通常有多个...【详细内容】
2020-11-10  Tags: innodb  点击:(120)  评论:(0)  加入收藏
从事务的隔离级别谈起众所周知,事务有四大特性,简称ACID:原子性、一致性、隔离性、持久性。对于隔离性,简单来说就是多个事务之间是彼此隔离的,互不影响。但想要做到完全的互不影...【详细内容】
2020-09-27  Tags: innodb  点击:(146)  评论:(0)  加入收藏
在MySql数据库的innodb存储引擎中,数据是按照主键以B+树的形式存储的。如果在建表的时候没有指定主键,那么引擎会自动添加一列主键。B+树B+树是一种平衡树,即根节点到各个叶子...【详细内容】
2020-09-09  Tags: innodb  点击:(152)  评论:(0)  加入收藏
InnoDB锁官方文档: https://dev.mysql.com/doc/refman/8.0/en/innodb-locking-transaction-model.html锁概念InnoDB 实现了以下两种类型的行级锁: 共享锁(S):允许一个事务去读一...【详细内容】
2020-08-21  Tags: innodb  点击:(46)  评论:(0)  加入收藏
我曾经在文章《MySQL 5.7 安装后的性能调优》(文末链接)和《MySQL 101:调整 MySQL 性能的参数》(文末链接)中谈到过 innodb_buffer_pool_instances 这个参数 ,建议使用值为“8”,但我不能说这个值是否足够好。因此,让我们看看...【详细内容】
2020-08-19  Tags: innodb  点击:(94)  评论:(0)  加入收藏
导读:InnoDB是事务安全的MySQL存储引擎,设计上采用了类似于Oracle数据库的架构。通常来说,InnoDB存储引擎是OLTP应用中核心表的首选存储引擎。同时,也正是因为InnoDB的存在,才使M...【详细内容】
2020-07-16  Tags: innodb  点击:(60)  评论:(0)  加入收藏
▌简易百科推荐
1增1.1【插入单行】insert [into] <表名> (列名) values (列值)例:insert into Strdents (姓名,性别,出生日期) values (&#39;开心朋朋&#39;,&#39;男&#39;,&#39;1980/6/15&#3...【详细内容】
2021-12-27  快乐火车9d3    Tags:SQL   点击:(1)  评论:(0)  加入收藏
最近发现还有不少做开发的小伙伴,在写存储过程的时候,在参考已有的不同的写法时,往往很迷茫, 不知道各种写法孰优孰劣,该选用哪种写法,以及各种写法的优缺点,本文以一个简单的查询...【详细内容】
2021-12-23  linux上的码农    Tags:sql   点击:(9)  评论:(0)  加入收藏
《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的HasorDB 是一个全功能数据库访问工具,提供对象映射、丰...【详细内容】
2021-12-22  GitHub精选    Tags:HasorDB   点击:(5)  评论:(0)  加入收藏
作者丨Rafal Grzegorczyk译者丨陈骏策划丨孙淑娟【51CTO.com原创稿件】您是否还在手动对数据库执行各种脚本?您是否还在浪费时间去验证数据库脚本的正确性?您是否还需要将...【详细内容】
2021-12-22    51CTO  Tags:Liquibase   点击:(3)  评论:(0)  加入收藏
场景描述:由于生产环境的表比较复杂,字段很多。这里我们做下简化,只为说明今天要聊的问题。有两张表 tab1,tab2: tab1 数据如下: tab2 数据如下: 然后给你看下,我用来统计 name=&#3...【详细内容】
2021-12-20  Bald    Tags:SQL   点击:(5)  评论:(0)  加入收藏
前言知识无底,学海无涯,知识点虽然简单,但是比较多,所以将MySQL的基础写出来,方便自己以后查找,还有就是分享给大家。一、SQL简述1.SQL的概述Structure Query Language(结构化查...【详细内容】
2021-12-16  谣言止于独立思考    Tags:SQL基础   点击:(13)  评论:(0)  加入收藏
前言作为一名测试工程师,工作中在对测试结果进行数据比对的时候,或多或少要和数据库打交道的,要和数据库打交道,那么一些常用的 SQL 查询语法必须要掌握。最近有部分做测试小伙...【详细内容】
2021-12-14  柠檬班软件测试    Tags:SQL   点击:(15)  评论:(0)  加入收藏
话说C是面向内存的编程语言。数据要能存得进去,取得出来,且要考虑效率。不管是顺序存储还是链式存储,其寻址方式总是很重要。顺序存储是连续存储。同质结构的数组通过其索引表...【详细内容】
2021-12-08  小智雅汇    Tags:数据存储   点击:(17)  评论:(0)  加入收藏
概述DBConvert Studio 是一款强大的跨数据库迁移和同步软件,可在不同数据库格式之间转换数据库结构和数据。它将成熟、稳定、久经考验的 DBConvert 和 DBSync 核心与改进的现...【详细内容】
2021-11-17  雪竹聊运维    Tags:数据库   点击:(26)  评论:(0)  加入收藏
一、前言 大家好,我是小诚,《从0到1-全面深刻理解MySQL系列》已经来到第四章,这一章节的主要从一条SQL执行的开始,由浅入深的解析SQL语句由客户端到服务器的完整执行流程,最...【详细内容】
2021-11-09  woaker    Tags:SQL   点击:(35)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条