MySQL创建表失败报错Row size too large的解决方案

Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

“varchar”的字段总和超过了65535,导致创建表失败。

二、解决方案:
缩减长度,如下所示。

CREATE TABLE t1 (a VARCHAR(10000),b VARCHAR(10000),c VARCHAR(10000),d VARCHAR(10000),e VARCHAR(10000),f VARCHAR(10000) ) ENGINE=MyISAM CHARACTER SET latin1;

请参考官方文档修改一个字段为TEXT类型。

MySQL的行大小限制是65535字节。这意味着单个行中的所有列和元数据的总字节数不能超过65535。当超出这个限制时,MySQL报错row size too large”。 如何解决mysql row size too large问题呢?有几个解决方案: 1. 把行拆成多个表: 这意味着把大表中的列分成两个或更多具有1:1关系的表。这样,每个表的行大小都小于MySQL的限制。 2. 使用BLOB或TEXT列: 这些列不计入行大小限制。因此,“row size too large”错误不会发生在BLOB和TEXT类型的列上。但是,在使用这些列时,需要注意性能问题,因为BLOB和TEXT类型的列需要更多的存储和处理资源。 3. 使用InnoDB存储引擎: InnoDB支持行大小大于65535字节的行。这是通过将大列存储在单独的磁盘页中来实现的,而不是直接在行中存储它们。但是,使用InnoDB存储引擎时,仍然需要遵循最佳实践和优化性能。 4. 使用压缩技术: 使用压缩技术可以减小每个行的大小。MySQL支持对列和行进行压缩,这可以减少存储需求并提高性能。但是,需要注意的是,压缩会增加CPU负载,因此需要在性能和存储需求之间进行权衡。 总体来说,就算遇到mysql row size too large问题,我们还是可以选择多种方法解决。选择哪种方法取决于具体情况下的性能和存储需求。最重要的是,不要让这个错误妨碍我们的工作,而是要通过切割、转换、优化和压缩等技术来找到解决方案
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值