Mysql行格式DYNAMIC和COMPACT区别

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 总之,选择哪种行格式取决于具体的应用场景,如数据类型分布、读写比例、存储与性能需求等。在处理大量文本或二进制数据且对存储空间敏感的应用中,DYNAMIC格式可能是更好的选择;而对于混合型数据且对读取性能有一定要求的场景,COMPACT格式可能更合适。在设计数据库时,评估这些因素并进行适当测试,可以帮助确定最适合的行格式。

MySQL的InnoDB存储引擎支持多种行格式,其中DYNAMIC和COMPACT是两种常见的行格式,它们各自有着不同的特性和应用场景。下面将详细对比这两种行格式的主要区别,以便于在设计数据库时做出合适的选择。

COMPACT行格式

COMPACT是MySQL 5.0之后引入的一种行记录存储方式,旨在提高数据页的利用率,使每个数据页能够存储更多的行记录。COMPACT格式的特点包括:

  1. 变长字段处理:对于VARCHAR、VARBINARY、BLOB等变长字段,COMPACT格式会在记录的真实数据部分存储实际长度和值。对于BLOB字段,如果数据超过768字节,超出部分会被存储到溢出页,记录中只保留20字节的指针指向溢出页。
  2. 固定长度字段优化:对于CHAR类型的字段,COMPACT格式会保留其声明的固定长度,即使实际存储的数据小于声明长度。
  3. 记录头部:COMPACT格式的记录头部包含了一些额外的信息,如记录的状态位、下一个记录的偏移量等,这有助于快速遍历记录和管理记录状态。

DYNAMIC行格式

从MySQL 5.7版本开始,DYNAMIC成为默认的行格式,它基于COMPACT格式进行了改进,主要区别在于处理大字段的方式:

  1. BLOB字段处理优化:与COMPACT格式相比,DYNAMIC行格式对于BLOB字段采取了更为激进的策略,无论BLOB字段的值大小如何,都只会直接在记录中存储一个20字节的指针指向溢出页,而不会在记录中保留任何实际数据。这种处理方式使得单个记录占用的空间更少,从而在数据页中可以存放更多的记录。
  2. 提高存储效率:由于DYNAMIC行格式对大字段的这种处理方式,它在存储大量含有大文本或二进制数据的表时,能更高效地利用存储空间,减少碎片化,尤其是在更新频繁导致行记录变长时。

区别总结

  • 空间利用率:DYNAMIC格式相比COMPACT格式,在处理大字段时更加节省记录内的空间,适合大量存储大文本或二进制数据的场景,而COMPACT格式则在某些情况下可能会因为存储部分BLOB数据而占用更多行内空间。
  • 性能考量:对于频繁读取BLOB字段的应用,COMPACT格式因能在某些情况下减少对溢出页的访问次数而稍微提升性能;而DYNAMIC格式则由于减少行记录大小,可能在索引扫描等操作上有更好的性能。
  • 更新操作:DYNAMIC格式由于减少行内存储的大字段数据,可能在行记录更新时减少行溢出页的重新分配,降低页面分裂的可能性,提高更新效率。

总之,选择哪种行格式取决于具体的应用场景,如数据类型分布、读写比例、存储与性能需求等。在处理大量文本或二进制数据且对存储空间敏感的应用中,DYNAMIC格式可能是更好的选择;而对于混合型数据且对读取性能有一定要求的场景,COMPACT格式可能更合适。在设计数据库时,评估这些因素并进行适当测试,可以帮助确定最适合的行格式。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
27天前
|
存储 Oracle 关系型数据库
Oracle和MySQL有哪些区别?从基本特性、技术选型、字段类型、事务、语句等角度详细对比Oracle和MySQL
从基本特性、技术选型、字段类型、事务提交方式、SQL语句、分页方法等方面对比Oracle和MySQL的区别。
Oracle和MySQL有哪些区别?从基本特性、技术选型、字段类型、事务、语句等角度详细对比Oracle和MySQL
|
1天前
|
存储 JSON 关系型数据库
MySQL 5.x和MySQL 8.x到底有什么区别?
本文详细对比了MySQL 5.x与MySQL 8.x的主要区别,包括存储引擎改进、性能提升、SQL语法增强(如窗口函数、CTE、JSON支持)、安全性和权限管理、并发及锁机制、InnoDB引擎增强、复制与高可用性等方面的显著差异。通过具体示例展示了8.x版本在企业级应用和高并发场景下的优越表现,建议有条件时尽早升级至MySQL 8.x以充分利用其新特性。
|
2天前
|
存储 关系型数据库 MySQL
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB区别,适用场景
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB——特点、性能、扩展性、安全性、适用场景比较
|
2月前
|
SQL 关系型数据库 MySQL
Mysql中from多表跟join表的区别
Mysql中from多表跟join表的区别
101 0
|
2月前
|
关系型数据库 MySQL
Mysql中count(1)、count(*)以及count(列)的区别
Mysql中count(1)、count(*)以及count(列)的区别
34 0
|
24天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
26天前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
192 11
|
1天前
|
SQL 关系型数据库 MySQL
|
21天前
|
存储 SQL 关系型数据库
MySQL的安装&数据库的简单操作
本文介绍了数据库的基本概念及MySQL的安装配置。首先解释了数据库、数据库管理系统和SQL的概念,接着详细描述了MySQL的安装步骤及其全局配置文件my.ini的调整方法。文章还介绍了如何启动MySQL服务,包括配置环境变量和使用命令行的方法。最后,详细说明了数据库的各种操作,如创建、选择和删除数据库的SQL语句,并提供了实际操作示例。
60 13
MySQL的安装&数据库的简单操作
|
27天前
|
存储 SQL 关系型数据库
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案
MySQL如何进行分库分表、数据迁移?从相关概念、使用场景、拆分方式、分表字段选择、数据一致性校验等角度阐述MySQL数据库的分库分表方案。
126 14
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案