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

相关推荐
南汐以墨9 小时前
一个另类的数据库-Redis
数据库·redis·缓存
RInk7oBjo10 小时前
spring-事务管理
数据库·sql·spring
希望永不加班10 小时前
SpringBoot 数据库连接池配置(HikariCP)最佳实践
java·数据库·spring boot·后端·spring
黑牛儿10 小时前
MySQL 索引实战详解:从创建到优化,彻底解决查询慢问题
服务器·数据库·后端·mysql
捧月华如11 小时前
RAG 入门-向量存储与企业级向量数据库 milvus
数据库·milvus
杨云龙UP11 小时前
Oracle Data Pump实战:expdp/impdp常用参数与导入导出命令整理_20260406
linux·运维·服务器·数据库·oracle
想唱rap11 小时前
线程池以及读写问题
服务器·数据库·c++·mysql·ubuntu
爱丽_12 小时前
B+ 树范围查询为什么快:页分裂/合并、索引设计与 SQL 写法优化
数据库·算法·哈希算法
better_liang13 小时前
每日Java面试场景题知识点之-MySQL索引
java·数据库·mysql·性能优化·索引
AgCl2313 小时前
MYSQL-4-DQL数据查询语言-3/14-15
数据库·mysql