MySQL 添加列报错处理

梦莱2年前技术文章1346

一、添加列报错(65535)

表添加列收到报错,具体 SQL 和报错信息如下:

ALTER TABLE table ADD column varchar(256) NULL COMMENT '个人打款授权书';

报错信息:Error 1118: 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

核实为 mysql 表有一个限制是 row size 不能超过 65535。查看表结构发现,表中有两个列都为 varchar (10000)。

L1VzZXJzL2VkeS9MaWJyYXJ5L0NvbnRhaW5lcnMvNVpTTDJDSlUyVC5jb20uZGluZ3RhbGsubWFjL0RhdGEvTGlicmFyeS9BcHBsaWNhdGlvbiBTdXBwb3J0L0RpbmdUYWxrTWFjLzEyNzUwODg3NjZfdjIvSW1hZ2VGaWxlcy8xNjg4Njk5NzQ3NDkxXzA0MEJCMkRCLTJDNDItNEFBRC04Mzk4LTUxRDAxQ0VEMzIwNS5wbmc=.png

MYSQL数据库中规定一条记录的最大长度是65535字节,定义到这个长度也会报错,行本身维护也会占用字节。不管任何存储引擎,都不能超过这个范围,即使存储引擎支持一行存储更长的数据。该限制为mysql server 层限制

建议:可以考虑下这两个字段的用途以及实际存储空间需要,如果存储较大数据的话,建议改为text或者blob。然后再去添加 personal_certificate varchar(256) 字段。text、blob会使用 溢出页 的方式存储,相对于 varchar(10000) 会释放一些 row size出来

二、添加列报错(8126)

添加 char 列报错情况,具体报错如下:

 ALTER TABLE partner_formal ADD personal_certificate char(256) NULL COMMENT '个人打款授权书';

Row size too large (> 8126). Changing some columns to TEXT or BLOB may help. In current row format, BLOB prefix of 0 bytes is stored inline

该限制为 innodb 引擎层限制,因为innodb 限制一条记录最多使用半个页面(即一个页面最少要记录两条数据),而默认情况下,Innodb页面大小是16KB,因此一条记录最大不能超过8126 字节。(如果一个页面的数据量不能存储2条记录,则这个B+树就不能称为B+树,因为它起不到一个索引的作用,其实就是一个双向链表,但比双向链表占用的空间大很多。如果不能够存储2条记录,那么这个B+树是没有意义的,形不成一个有效的索引)

如果使用 varchar(),在创建列的时候不报错,但是后续插入数据,如果达到 8126字节,还是会报错导致数据无法插入;因为 char 是定长,相当于已经分配好的字节,而 varchar 是变长,但后续数据插入达到限制会导致数据插入不进去。


相关文章

PG查询性能Top SQL

一、查询当前正在运行的Top SQL    查询当前正在运行的会话中耗时最长的Top SQL,where条件可按需修改SELECT pgsa.datname AS database_name    ...

磁盘分区与挂载

磁盘分区与挂载

背景当我们新建一个服务器时,需要对磁盘进行分区、格式化、挂载等操作。那么我们应该如何进行呢?一、LVM技术1、安装所需的lvm工具yum install -y lvm22、创建物理卷PVpvcreat...

网络数据链路层-MAC帧(1)

网络数据链路层-MAC帧(1)

1.数据链路层数据链路层是网络协议栈中最底层的内容,而在之前对其他层次的学习让我们知道传输层可以保证数据的可靠性问题,网络层保证数据跨网络转发的路由问题,而数据链路层解决的就是局域网内两台主机间通信的...

CDH实操--集群卸载

CDH实操--集群卸载

1、停止正在运行的服务a、控制台停止集群服务b、控制台停止Cloudera Management Servicec、命令行停止cm服务systemctl stop cloudera-scm-agent...

pg_dump

逻辑备份    PG提供了pg_dump、pg_dumpall两种方式进行逻辑备份,其区别就是pg_dumpall只能将数据库全部数据集dump到一个脚本文件中,而pg_dump可以选择指定数据库进行...

kafka单条消息过大导致线上OOM

1 线上问题kafka生产者罢工,停止生产,生产者内存急剧升高,导致程序几次重启。查看日志,发现Produce程序爆异常kafka.common.MessageSizeTooLargeExceptio...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。