mysql 的一行记录是怎么存储的?
Posted 程序员小灰
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 的一行记录是怎么存储的?相关的知识,希望对你有一定的参考价值。
https://dev.mysql.com
https://dev.mysql.com/downloads/mysql/5.7.html
mysql> SHOW VARIABLES LIKE 'datadir';
+---------------+---------------------------------------------+
| Variable_name | Value |
+---------------+---------------------------------------------+
| datadir | C:\ProgramData\MySQL\MySQL Server 5.7\Data\ |
+---------------+---------------------------------------------+
1 row in set, 1 warning (0.00 sec)
第一步:创建数据库
第一步:创建数据库
mysql> create database flash;
data:image/s3,"s3://crabby-images/0f658/0f65851e31f389dafbf042580f3ec459ec55b18c" alt="mysql 的一行记录是怎么存储的?"
|-- flash
|-- db.opt
|-- flash
|-- performance_schema
default-character-set=latin1
default-collation=latin1_swedish_ci
ALTER SCHEMA `flash` DEFAULT CHARACTER SET utf8mb4;
default-character-set=utf8mb4
default-collation=utf8mb4_general_ci
第二步:创建表
第二步:创建表
CREATE TABLE `flash`.`student` (
`id` INT NOT NULL,
`name` VARCHAR(10) NOT NULL,
`age` INT NULL,
PRIMARY KEY (`id`)
ENGINE = InnoDB
DEFAULT CHARACTER SET = utf8mb4;
|-- db.opt
|-- student.frm
|-- student.ibd
|-- flash
|-- performance_schema
为了严谨,我们先看下 db.opt 文件有没有变化,发现没有任何变化,说明创建表对这个 db.opt 配置信息文件,没有影响。
data:image/s3,"s3://crabby-images/9ab92/9ab922d5bc15d2659e825cc0ce5ca94b573aaab5" alt="mysql 的一行记录是怎么存储的?"
data:image/s3,"s3://crabby-images/5d860/5d860d2767afafdf5d3a30ed31f4525d6baf4da9" alt="mysql 的一行记录是怎么存储的?"
data:image/s3,"s3://crabby-images/937bf/937bf84f9b280dbb8ae92df70c5dcf0256707e14" alt="mysql 的一行记录是怎么存储的?"
第三步:插入数据
INSERT INTO `flash`.`student` (`id`, `name`, `age`) VALUES ('1', 'dibingfa2', '2');
INSERT INTO `flash`.`student` (`id`, `name`, `age`) VALUES ('2', 'dibingfa2', '2');
INSERT INTO `flash`.`student` (`id`, `name`, `age`) VALUES ('3', 'dibingfa3', '2');
INSERT INTO `flash`.`student` (`id`, `name`, `age`) VALUES ('4', 'dibingfa4', '2');
INSERT INTO `flash`.`student` (`id`, `name`, `age`) VALUES ('5', 'dibingfa5', '2');
INSERT INTO `flash`.`student` (`id`, `name`, `age`) VALUES ('6', 'dibingfa6', '2');
INSERT INTO `flash`.`student` (`id`, `name`, `age`) VALUES ('7', 'dibingfa7', '2');
再二进制打开它!
data:image/s3,"s3://crabby-images/82eaa/82eaa744de4b3feae8e0b7c97313728268b12fd5" alt="mysql 的一行记录是怎么存储的?"
data:image/s3,"s3://crabby-images/291a1/291a1793cb436dca94b296eb08929db660ae1aa5" alt="mysql 的一行记录是怎么存储的?"
data:image/s3,"s3://crabby-images/8efff/8efff08753fc7d85b0a8afd277bb0ae8eb53f0eb" alt="mysql 的一行记录是怎么存储的?"
data:image/s3,"s3://crabby-images/a7517/a75173535149eacf12f266e5e14dd6ebc468235e" alt="mysql 的一行记录是怎么存储的?"
| length of the last non-null variable-length field of data ... ...|
...
| length of first variable-length field of data |
data:image/s3,"s3://crabby-images/c08e9/c08e9d3002d0080a5a4b3fbed3286dc5ea0269fc" alt="mysql 的一行记录是怎么存储的?"
data:image/s3,"s3://crabby-images/470df/470dff75a17b44646c8254f829d94c961a0fa029" alt="mysql 的一行记录是怎么存储的?"
data:image/s3,"s3://crabby-images/375ff/375ff63149f2fd787270000bba7f65303d4dade9" alt="mysql 的一行记录是怎么存储的?"
| 4 bits used to delete mark a record, and mark a predefined
minimum record in alphabetical order |
| 4 bits giving the number of records owned by this record
(this term is explained in page0page.h) |
| 13 bits giving the order number of this record in the
heap of the index page |
| 3 bits record type: 000=conventional, 001=node pointer (inside B-tree),
010=infimum, 011=supremum, 1xx=reserved |
| two bytes giving a relative pointer to the next record in the page |
ORIGIN of the record
data:image/s3,"s3://crabby-images/424cd/424cd4ece5b1514db747ce0505ae919399f1d84f" alt="mysql 的一行记录是怎么存储的?"
| first field of data |
...
| last field of data |
主键 ID:80 00 00 01
事务 ID:00 00 00 00 0A 07
回滚指针:A7 00 00 01 1B 01 10
name 列(dibingfa):64 69 62 69 6E 67 66 61
age 列(2):80 00 00 02
行记录格式整体结构
/** Innodb row types are a subset of the MySQL global enum row_type.
They are made into their own enum so that switch statements can account
for each of them. */
enum rec_format_enum {
REC_FORMAT_REDUNDANT = 0, /*!< REDUNDANT row format */
REC_FORMAT_COMPACT = 1, /*!< COMPACT row format */
REC_FORMAT_COMPRESSED = 2, /*!< COMPRESSED row format */
REC_FORMAT_DYNAMIC = 3 /*!< DYNAMIC row format */
};
static ulong innodb_default_row_format = DEFAULT_ROW_FORMAT_DYNAMIC;
变长字段列表
NULL 值列表
记录头信息
data:image/s3,"s3://crabby-images/45044/450445a10f3639aa8fce60a997cbdaf9f9c55484" alt="mysql 的一行记录是怎么存储的?"
再聊几句
以上是关于mysql 的一行记录是怎么存储的?的主要内容,如果未能解决你的问题,请参考以下文章