MySQL数据库——InnoDB引擎-逻辑存储结构(表空间、段、区、页、行)

目录

表空间


之前我们初步介绍过InnoDB引擎的逻辑存储结构,如下图所示:

下面来对其每个组成部分详细了解:

表空间

表空间 是InnoDB存储引擎逻辑结构的最高层, 如果用户启用了参数 innodb_file_per_table(在

8.0版本中默认开启) ,则每张表都会有一个表空间(xxx.ibd),一个mysql实例可以对应多个表空
间,用于存储记录、索引等数据。

段,分为数据段(Leaf node segment)、索引段(Non-leaf node segment)、回滚段
(Rollback segment),InnoDB是索引组织表,数据段就是B+树的叶子节点, 索引段即为B+树的

非叶子节点。段用来管理多个Extent(区)。

区,表空间的单元结构,每个区的大小为1M。 默认情况下, InnoDB存储引擎页大小为16K, 即一个区中一共有64个连续的页。

页,是InnoDB 存储引擎磁盘管理的最小单元,每个页的大小默认为 16KB。为了保证页的连续性,InnoDB 存储引擎每次从磁盘申请 4-5 个区

行,InnoDB 存储引擎数据是按行进行存放的。在行中,默认有两个隐藏字段:

  • Trx_id:每次对某条记录进行改动时,都会把对应的事务id赋值给trx_id隐藏列。
  • Roll_pointer:每次对某条引记录进行改动时,都会把旧的版本写入到undo日志中,然后这个隐藏列就相当于一个指针,可以通过它来找到该记录修改前的信息。

END


学习自:黑马程序员------MySQL数据库课程

相关推荐
蒋星熠2 分钟前
中间件架构设计与实践:构建高性能分布式系统的核心基石
开发语言·数据库·分布式·python·中间件·性能优化·硬件工程
Agatha方艺璇7 分钟前
CentOS7 Hive2.3.8 安装图文教程
大数据·数据库
凯尔萨厮10 分钟前
Java学习笔记四(继承)
java·笔记·学习
ホロHoro16 分钟前
学习笔记:Javascript(5)——事件监听(用户交互)
javascript·笔记·学习
花菜会噎住22 分钟前
MySQL 高级特性与性能优化:深入理解函数、视图、存储过程、触发器
android·mysql·函数·索引·视图
悟乙己27 分钟前
PySpark 与 Pandas 的较量:Databricks 中 SQL Server 到 Snowflake 的数据迁移之旅
数据库·pandas·pyspark
爱喝水的鱼丶35 分钟前
SAP-MM:SAP核心组织单元:工厂(Plant)全面学习指南及配置图解
学习·sap·abap·配置·工厂·mm模块
程序新视界35 分钟前
数据库之必备经验视角:什么是N+1查询问题?
mysql
励志不掉头发的内向程序员36 分钟前
STL库——AVL树
开发语言·c++·学习
My is 李豆3 小时前
CentOS 7 安装 MySQL 详细教程
mysql·centos