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


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

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

于是之前是这个样子

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

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

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM