Mysql 行存储的文件格式

一、Mysql行存储的文件格式概述

InnoDB存储引擎有两种文件格式

Antelope:compact与redundant两种行记录格式

Barracuda:compress与dynamic两种行记录格式

查看表的行记录格式:

show table status like '%sys_appinfo%'\G;

查看数据库默认的行记录格式:

show variables like '%row_format%';

文件格式查看方式:

show variables like 'innodb_file%';('innodb_file)

二、四种行记录格式的不同

MySQL5.7默认使用Barracuda文件格式与dynamic行记录格式。

compact是目前使用最多的一种,而dynamic时新版本默认的行记录格式。

在生产中,我们应该选择哪种行记录格式?

这要说明行溢出:行溢出简单来讲就是需要存储的数据在当前页面之外,拆分到多个页进行存储。

针对大数据类型text或者blob存储在其字段中的数据,dynamic实际采用的数据都存放在溢出的

页中(off-page),而数据页只存储前20个字节指针。在compact行格式下,溢出的列只存放768个

前缀字节。dynamic这种行格式模式,针对溢出列所在的新页利用率更高。所以,目前生产环境

中建议尽量使用dynamic这种行格式模式,针对溢出列所在的新页利用率更高。

redundant是最早的行记录格式,相比compact要消耗更多的存储空间,不建议使用。

compressed是压缩格式,是对数据和索引进行压缩。但只是针对物理存储层面上的压缩,而在

内存中是不压缩的。当数据调用到内存中就涉及到转换,会很消耗CPU资源,而且效率很低。

压缩比不高,大概直接进1/2的比例。压缩带来负面影响大,数据库TPS会下降,影响现有的线上业务,

不建议使用。

 

转载于:https://www.cnblogs.com/xibuhaohao/p/10717256.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值