Row size too large (> 8126). Changing some columns to TEXT or BLOB or using ROW_FORMAT=DYNAMIC or RO

CREATE TABLE IF NOT EXISTS `jshop_weixin_author` (
  `id` int(10) NOT NULL,
  `nick_name` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '授权方昵称',
  `head_img` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '授权方头像',
  `service_type_info` varchar(10) CHARACTER SET utf8 DEFAULT '0' COMMENT '默认为0',
  `verify_type_info` tinyint(1) DEFAULT '-1' COMMENT '授权方认证类型,-1代表未认证,0代表微信认证',
  `user_name` varchar(200) CHARACTER SET utf8 DEFAULT NULL COMMENT '小程序的原始ID',
  `signature` tinytext CHARACTER SET utf8 COMMENT '帐号介绍',
  `principal_name` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '小程序的主体名称',
  `business_info` text CHARACTER SET utf8 COMMENT '用以了解以下功能的开通状况(0代表未开通,1代表已开通): open_store:是否开通微信门店功能 open_scan:是否开通微信扫商品功能 open_pay:是否开通微信支付功能 open_card:是否开通微信卡券功能 open_shake:是否开通微信摇一摇功能',
  `qrcode_url` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '二维码图片的URL',
  `authorization_info` text CHARACTER SET utf8 COMMENT '授权信息',
  `appid` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '授权方appid',
  `appsecret` varchar(100) CHARACTER SET utf8 DEFAULT NULL COMMENT '授权方AppSecret',
  `miniprograminfo` tinytext CHARACTER SET utf8 COMMENT '可根据这个字段判断是否为小程序类型授权,有值为小程序',
  `func_info` text CHARACTER SET utf8 COMMENT '小程序授权给开发者的权限集列表,ID为17到19时分别代表: 17.帐号管理权限 18.开发管理权限 19.客服消息管理权限 请注意: 1)该字段的返回不会考虑小程序是否具备该权限集的权限(因为可能部分具备)',
  `authorizer_refresh_token` varchar(200) CHARACTER SET utf8 DEFAULT NULL COMMENT '刷新token',
  `authorizer_access_token` varchar(200) CHARACTER SET utf8 DEFAULT NULL COMMENT 'token',
  `bind_type` tinyint(1) unsigned DEFAULT '2' COMMENT '绑定类型,1为第三方授权绑定,2为自助绑定',
  `author_type` varchar(10) CHARACTER SET utf8 DEFAULT 'b2c' COMMENT '授权类型,默认b2c',
  `expires_in` int(10) unsigned DEFAULT '0' COMMENT '绑定授权到期时间',
  `ctime` int(10) unsigned DEFAULT '0' COMMENT '小程序授权时间',
  `utime` int(10) unsigned DEFAULT '0' COMMENT '小程序更新时间'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=COMPACT COMMENT='获取授权方的帐号基本信息表';

Row size too large (> 8126). Changing some columns to TEXT or BLOB or using ROW_FORMAT=DYNAMIC or ROW_FORMAT=COMPRESSED may help. In current row format, BLOB prefix of 768 bytes is stored inline.

【导致问题的原因】

总结了下原因是因为mysql-innodb是按照page存储数据的,每个page max size是16k,然后每个page两行数据,所以每行最大8k数据。如果你的字段是blob之类的话,会存储在page之外的溢出区里。

但是innodb默认的approach(羚羊)存储格式会把每个blob字段的前864个字节存储在page里,所以你的blob超过一定数量的话,单行大小就会超过8k,所以就报错了

我处理的这张表有400列,有大量的VARCHAR和TEXT列,以前遇到过该表中VARCHAR总长度超过65532的错误,第一眼看到,误以为是VARCHAR超长的问题。

【尝试一】于是我把一些较大的VARCHAR列换成了TEXT类型,但是问题依然存在。

【尝试二】根据错误信息的提示,我又在创建表时添加了ROW_FORMAT=DYNAMIC设置,但是问题依然存在。

【尝试三】后来我怀疑数据库引擎的问题,因为我们常用的是MyISAM引擎,但是我新装mysql后,默认是InnoDb,而我也一直没有修改。于是我移除了创建表时的ROW_FORMAT设置,增加了Engine=MyISAM。问题解决了。

【原理浅析】根据网上的一些资料,这个问题可能与不同引擎之间使用的存储格式有关。MyISAM有3种行存储格式:fixed/dynamic/compressed。InnoDb在MyIASM基础上新引入了Barracuda。至于不同引擎的默认设置,以及各种存储格式之间的区别,我也没有深入研究,有兴趣的话可以去了解一下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值