写点什么

✅MySQL 的 InnoDB 存储引擎支持哪几种行格式?

作者:派大星
  • 2024-04-17
    辽宁
  • 本文字数:778 字

    阅读完需:约 3 分钟

数据库表中的行格式决定了数据在物理存储时的布局方式,进而对查询和 DML 操作的性能产生影响。


在 InnoDB 存储引擎中,常见的行格式主要包括以下四种:


  1. COMPACT:在 MySQL 5.0 之前是默认的格式,除了存储字段值外,还会利用空值列表来保存 null 值,同时记录变长字段长度列表和记录头信息。



COMPACT 适用于处理大量包含可变长度列(如 VARCHAR、VARBINARY、BLOB 和 TEXT 类型)数据。


对于可变长度列,前 768 字节的数据存储在 B 树节点的索引记录中,超出部分存储在溢出页中。大于或等于 768 字节的固定长度列会被编码为可变长度列,可以存储在页外。


  1. REDUNDANT:在 MySQL 5.0 版本之前,InnoDB 使用的行记录存储方式,较少使用。Redundant 行格式会将该记录中所有列(包括隐藏列)的长度信息存储在“字段长度偏移列表”中。



  1. DYNAMIC:MySQL 5.7 版本引入的 DYNAMIC 格式是 COMPACT 格式的升级版本。它延续了 COMPACT 格式的优势,在处理大型可变长度列时更具灵活性,能够灵活选择将数据存储在页内还是页外。DYNAMIC 格式适用于多数应用场景,在存储空间和性能之间取得了一定的平衡。其结构与 COMPACT 格式大致相似;

  2. COMPRESSED:作为 MySQL 5.1 中 InnoDB 的新增特性之一,压缩功能能够减小数据在磁盘上的占用空间。然而,其缺点在于增加了 CPU 的负担,可能导致部分查询性能下降。COMPRESSED 行格式在 DYNAMIC 行格式的基础上引入了页外压缩功能。在存储数据时,如果发现可以通过压缩来减小存储空间,系统将选择压缩方式来存储数据。在查询时,数据将会被自动解压并返回结果。

  3. BARRACUDA:作为 MySQL 5.7 引进的一种新格式,相较于前述格式,支持更多高级特性,包括动态行格式、逐行压缩以及空间管理等功能。

对比:


如有问题,欢迎加微信交流:w714771310,备注- 技术交流  。或微信搜索【码上遇见你】。


免费的Chat GPT可微信搜索【AI贝塔】进行体验,无限使用。


好了,本章节到此告一段落。希望对你有所帮助,祝学习顺利。

发布于: 刚刚阅读数: 4
用户头像

派大星

关注

微信搜索【码上遇见你】,获取更多精彩内容 2021-12-13 加入

微信搜索【码上遇见你】,获取更多精彩内容

评论

发布
暂无评论
✅MySQL的InnoDB存储引擎支持哪几种行格式?_事务_派大星_InfoQ写作社区