前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL的InnoDB存储引擎支持哪几种行格式?

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

作者头像
@派大星
发布2024-04-15 13:56:34
2170
发布2024-04-15 13:56:34
举报
文章被收录于专栏:码上遇见你

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

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

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

image.png

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

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

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

image.png

  1. DYNAMIC:MySQL 5.7版本引入的DYNAMIC格式是COMPACT格式的升级版本。它延续了COMPACT格式的优势,在处理大型可变长度列时更具灵活性,能够灵活选择将数据存储在页内还是页外。DYNAMIC格式适用于多数应用场景,在存储空间和性能之间取得了一定的平衡。其结构与COMPACT格式大致相似;
  2. COMPRESSED:作为MySQL 5.1中InnoDB的新增特性之一,压缩功能能够减小数据在磁盘上的占用空间。然而,其缺点在于增加了CPU的负担,可能导致部分查询性能下降。COMPRESSED行格式在DYNAMIC行格式的基础上引入了页外压缩功能。在存储数据时,如果发现可以通过压缩来减小存储空间,系统将选择压缩方式来存储数据。在查询时,数据将会被自动解压并返回结果。
  3. BARRACUDA:作为MySQL 5.7引进的一种新格式,相较于前述格式,支持更多高级特性,包括动态行格式、逐行压缩以及空间管理等功能。

对比:

行格式

紧凑的存储特性

增强的可变长度列存储

大索引键前缀支持

压缩支持

支持的表空间类型

所需文件格式

REDUNDANT

system, file-per-table, general

Antelope or Barracuda

COMPACT

system, file-per-table, general

Antelope or Barracuda

DYNAMIC

system, file-per-table, general

Barracuda

COMPRESSED

file-per-table, general

Barracuda

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

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-04-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码上遇见你 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 对比:
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档