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值,

相关推荐
014-code5 分钟前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
运气好好的6 分钟前
怎样开启phpMyAdmin的操作审计日志_记录每条执行的SQL
jvm·数据库·python
それども1 小时前
DELETE 和 TRUNCATE TABLE区别
java·数据库·mysql
wenha1 小时前
数据库隔离级别
数据库·mysql·sqlserver·隔离级别
2401_871492851 小时前
Layui如何修改Layui默认的UI主题颜色(换肤功能实现)
jvm·数据库·python
Edward111111112 小时前
4.27mysql ,数据库,数据源
数据库·mysql
小徐敲java2 小时前
踩坑实录:MySQL8.0 导入SQL报错 2006 - MySQL server has gone away 完美解决
数据库·sql
别来无恙blwy2 小时前
windows MongoDB升级-自动升级脚本-自动检测升级到任意版本
数据库·windows·mongodb
步辞2 小时前
Redis如何利用LFU算法优化缓存命中率
jvm·数据库·python
~小先生~2 小时前
sqlserver 外键、级联使用
数据库·sqlserver