InnoDB(1)变长字段长度列表--mysql从入门到精通(六)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: InnoDB(1)变长字段长度列表--mysql从入门到精通(六)

上篇文章我们总结了mysql字符集:

Mysql字符集总结(4)--mysql从入门到精通(五)



我们现在已经知道了,mysql客户端到服务器字符集是如何编码解码的,但表中数据到底存在哪里?以什么格式存放?mysql以什么方式访问这些数据?这些我们都会在下面一一解答。


我们之前说到过mysql-service和存储引擎,mysql-service包含tcp/ip连接、查询缓存,解码sql语句,优化sql语句。Mysql服务器支持不同的存储引擎,如InnoDB、MyISAM、Memory等,不同的存储引擎拥有不同的性能,存放的格式也是不同的,甚至memory都不是吧数据存在磁盘中,也就是服务器关闭,数据就会消息。而InnoDB和myISAM是我们常用的两个存储引擎,所以就先重点介绍支持事务的InnoDB。


InnoDB存储引擎


InnoDB是一个吧数据写入磁盘中的存储引擎,所以服务器宕机或者重启,数据都不会消失。而真正处理数据是在内存中,所以我们需要把磁盘上的数据写入内存,当在内存中处理新增或者修改数据时候,又会把内存中的数据刷新到磁盘上。我们知道处理内存和处理磁盘上的数据,运行和反映速度不在一个量级,所以在select数据的时候,难道从磁盘中一行一行查吗?当然不是,InnoDB解决的办法是,将数据分为若干页,每一页大小大概16kb。也就是一般情况下,最少从磁盘读取16kb到内存中,一次也是最少吧16kb的数据刷新到磁盘上。


先来创建一个compact_tb表,指定字符集为ascii,指定行格式为compact。还可以用另一个语句指定行格式,如下。

//创建的时候指定行格式
create TABLE compact_tb(
  c1 VARCHAR(10),
  c2 VARCHAR(10) NOT NULL,
  c3 CHAR(10),
  c4 VARCHAR(10)
) CHARSET=ascii ROW_FORMAT=COMPACT;
//另一个方法指定行格式
ALTER TABLE COMPACT_TB ROW_FORMAT=COMPACT;


因为ascii字符集不包含汉字,只有空格,大小写字母,数字,标点符号等不可见字符,所以我们insert进表的时候不要存汉字,insert语句如下,查询之后就是这样:

INSERT INTO compact_tb(c1, c2, c3, c4) VALUES('aaaa', 'bbb', 'cc', 'd'), ('eeee', 'fff', NULL, NULL);
//查询
 select * from compact_tb;
+------+-----+------+------+
| c1   | c2  | c3   | c4   |
+------+-----+------+------+
| aaaa | bbb | cc   | d    |
| eeee | fff | NULL | NULL |
+------+-----+------+------+
2 rows in set (0.00 sec)


compact行格式:


一条完整的信息记录分为:“记录的额外信息”和“记录的真是数据”两大部分


一、记录的额外信息


真是数据顾名思义就是存储我们需要的数据信息,而额外信心存储的是不得不存储的描述这些数据的信息,分别有三个部分,“变长字段长度列表”、“null值列表”和“记录头信息”。


VARCHAR(M),VARBINARY(M)、text类型,各种BLOB类型都属于边长字段,这些存储多少数据都是不固定的,mysql为了方便存储,吧这些数据分为两个部分,一是真正的数据内容,二时这些内容占用的字节数。


在compact中,吧所有变长字段真实数据字节长度都存在记录开头部分,从而形成变长字段长度列表,各变长字段的长度按逆袭存放,按逆袭存放,按逆袭存放。(重要的事要说三遍)


我们拿插入的第一列为例,

C1字段的‘aaaa‘十进制表示4,十六进制表示0x04

C2字段的‘bbb’十进制表示3,十六进制表示0x03

C4字段的‘d’ 十进制表示1,十六进制表示0x01

因为c3是char类型,不是变长字段。

所以这些数据存入变长字段长度列表为:010304

上诉情况都是因为存储的字段小,都是用一个字节,那么innoDB表如果存储两个字节呢?innoDB有他字节的规则,我们创建字段的时候会有varchar(M),假设字符集中站用一个字符的字节数为W,utf8的占用字节数W为3,gbk一个字符占用字节数为2,ascii占用一个字符的字节数为1。规则如下:

当M*W<=255时候,存储的都是一个字节数。

当M*W>255时候:

如果存储的真实字节长度<127,则用一个字节存储。

如果存储的真实字节长度>127,则用两个字节存储。

另外需要注意的是,变长字段长度只存储非NULL的数据,若为null则不存储了,下篇文章介绍innoDB表的null值如何存储。另外,不是所有数据都有变长字段长度部分的存储,比方说表里都没有变长字段长度部分,就不需要这个存储区间。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
20 8
|
11天前
|
关系型数据库 MySQL Java
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
20 0
|
29天前
|
SQL 存储 关系型数据库
MySQL新增字段/索引会不会锁表?
MySQL新增字段/索引会不会锁表?
|
2月前
|
SQL 关系型数据库 MySQL
MySQL数据库中给表添加字段并设置备注的脚本编写
通过上述步骤,你可以在MySQL数据库中给表成功添加新字段并为其设置备注。这样的操作对于保持数据库结构的清晰和最新非常重要,同时也帮助团队成员理解数据模型的变化和字段的具体含义。在实际操作中,记得调整脚本以适应具体的数据库和表名称,以及字段的详细规范。
55 8
|
1月前
|
SQL 关系型数据库 MySQL
MySQL 查询某个字段含有字母数字的值
MySQL 查询某个字段含有字母数字的值
58 0
|
1月前
|
存储 关系型数据库 MySQL
MySQL 字符字段长度设置详解:语法、注意事项和示例
MySQL 字符字段长度设置详解:语法、注意事项和示例
161 0
|
1月前
|
关系型数据库 MySQL 数据库管理
MySQL技术指南:如何更改数据字段的前几位数字
MySQL技术指南:如何更改数据字段的前几位数字
53 0
|
1月前
|
存储 缓存 关系型数据库
详细解析MySQL中的innodb和myisam
总之,InnoDB和MyISAM各有千秋,选择合适的存储引擎应基于对应用程序特性的深入理解,以及对性能、数据完整性和可扩展性的综合考量。随着技术发展,InnoDB因其全面的功能和日益优化的性能,逐渐成为更广泛场景下的首选。然而,在特定条件下,MyISAM依然保留其独特的价值。
103 0
|
3月前
|
监控 关系型数据库 MySQL
在Linux中,mysql的innodb如何定位锁问题?
在Linux中,mysql的innodb如何定位锁问题?
|
2月前
|
SQL 关系型数据库 MySQL
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
152 0
下一篇
无影云桌面