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

我处理的这张表有140列,有大量的VARCHAR和TEXT列,第一眼看到,误以为是VARCHAR超长的问题。于是把几个长度较长的字段改为text了,但是依旧报错,而且并不提示是哪个字段超长了,索性就把表里所有字段全都改成text类型,结果还是报错。。。。。

到网上搜了一下,可能和引擎有关系

于是之前是这个样子

改成,主要改了引擎和格式

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

 

转载于:https://www.cnblogs.com/zhouhao666/p/9817964.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值