MySQL从入门到精通系列:InnoDB记录存储结构

一:楔子

MySQL服务器当中用于对表数据进行操作的是存储引擎。 常用的存储引擎是InnoDB MyISAM MEMORY

MySQL默认的存储引擎是InnoDB。我们本系列文章,研究的也就是这个存储引擎。

二:页简介

InnoDB的数据存储到磁盘上。

真正处理数据的过程发生在内存中,所以需要把磁盘中的数据加载到内存中。如果是处理写入或修改 请求,还需要把内存中的内容刷新到磁盘上

然而读写磁盘的速度非常慢,与读写内存差了几个数量级。存储引擎需要一条一条地把记录从磁盘上读出来么?不,那样会慢死。

InnoDB采取的方式是:将数据划分为若干个页,以页作为磁盘和内存之间交互的基本单位。InnoDB中页的大小一般为16KB。也就是在一般情况下,一次最少从磁盘中读取16KB的内容到内存中,一次最少把内存中的16KB内容刷新到磁盘中。

注意:

系统变量innodb_page_ size表明了InnoDB存储引擎中的页大小,默认值为16384(单位是字节),也就是16KB。

该变量只能在第一次初始化MySQL数据目录时指定,之后就再也不能更改了

服务器运行过程中不可以更改页面大小就好了

三:行格式

表中数据的单位是记录,记录有四种行格式:

compact、redundant、dynamic、compressed

1:指定行格式语法

复制代码
# 建表时指定
CREATE TABLE `xxxxxxx` (
  `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',
  `encrypted_data_key` varchar(1024) COLLATE utf8mb3_bin NOT NULL DEFAULT '' COMMENT '密钥',
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_configinfo_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8mb3_bin ROW_FORMAT=compact

# alter进行修改
alter table xxxxrow_format=conpact;

2:指定compact行格式

额外信息的作用

辅助管理、标记真实记录。

变长字段列表:

MySQL中有变长数据类型Varchar(M) Varbinary(M) Text BloBl类型。这种列数据存储内容长度是多少并不确定

存储行中包含这种列的时候,要存储真实值+内存长度(数据占用字节数)Compact格式中,一行中变长字段真实数据字节数,逆序存储在这个列表当中。按列顺序逆序排列。

Null值列表:

某些列是null值,

相关推荐
这个DBA有点耶7 分钟前
时序数据库选型:吞吐、压缩与查询延迟的均衡之术
数据库·sql·架构·时序数据库·dba
snow@li7 分钟前
数据库:MySQL vs PostgreSQL 详尽对比(2026版)
java·mysql·postgresql
luck_bor10 分钟前
数据库简介
数据库·oracle
hikktn20 分钟前
Oracle批量UPDATE空值覆盖陷阱:CASE WHEN优雅防御方案【宗申集团】
数据库·oracle
Han_han91924 分钟前
数据库基本操作:
数据库
J.Kuchiki37 分钟前
【PostgreSQL 内核学习:平衡 K 路归并(Balanced k-way Merge)】
数据库·学习·postgresql
xieliyu.44 分钟前
MySQL 全套入门笔记:基础、库操作、数据类型
数据库·笔记·mysql
lvbinemail1 小时前
【无标题】
数据库·postgresql·zabbix·监控
技术小甜甜1 小时前
[办公效率] Excel 表格越做越乱,先整理字段、格式还是公式?
数据库·excel·办公效率·数据整理
Data-Miner1 小时前
休闲食品行业数据分析平台建设方案,揭秘增长新引擎!
大数据·数据库·数据分析