mysql创建表报错:ERROR 1118 (42000) ...Row size too large (> 8126)

当尝试在MySQL中创建表时,如果单行所有列的总字节长度超过8126(对于某些存储引擎),会出现ERROR1118错误。解决方法包括将某些列转换为TEXT或BLOB类型,或者使用DYNAMIC或COMPRESSED的ROW_FORMAT。此外,可以考虑减小VARCHAR列的长度限制来遵守65535字节的行格式限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysql创建表报错:ERROR 1118 (42000) ...Row size too large (> 8126)

ERROR 1118 (42000) at line 175: 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建表的单行的所有列字段之和的总字节长度不能超过65535。

解决方案,最简单的方法,列的宽带在varchar():

varchar(设置的长度值)

定义 设置的长度值 调小一些。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangphil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值