您的位置:首页 > 数据库 > MySQL

MySql “Row size too large (> 8126)”

2016-03-02 20:14 906 查看
今天在对MySQL数据库进行数据处理时,遇到一个错误:

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

我处理的这张表有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。至于不同引擎的默认设置,以及各种存储格式之间的区别,我也没有深入研究,有兴趣的话可以去了解一下。

【InnoDb的解决方案】后来我在stackoverflow中看到了InnoDb中的解决方案(未尝试):

http://stackoverflow.com/questions/15585602/change-limit-for-mysql-row-size-too-large





【其他问题】另外,stackoverflow上还提到了日志文件设置过小也可能引起该问题的情况:

http://stackoverflow.com/questions/22637733/mysql-error-code-1118-row-size-too-large-8126-changing-some-columns-to-te

http://www.alanzeng.cn/2016/03/mysql-row-size-too-large-8126/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息