MySQL 添加列报错处理

梦莱2年前技术文章1621

一、添加列报错(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 是变长,但后续数据插入达到限制会导致数据插入不进去。


相关文章

Greenplum数据库建立外部表加载HDFS文件实践指导

Greenplum数据库建立外部表加载HDFS文件实践指导

环境概述(1)     Greenplum数据库版本号Greenplum Database 4.3.0.0POC3 build 45206(基于PostgreS...

触发kube-apiserver流控导致ACK集群中节点状态异常

触发kube-apiserver流控导致ACK集群中节点状态异常

问题现象ack集群中一个节点状态为notready,但是排查节点上的核心组件:kubelet、kube-proxy、flannel、etcd等状态均为正常。排查步骤1、查日志分别排查核心组件以及系统日...

hive 报 找不到或无法加载主类 org.apache.hadoop.mapreduce.v2.app.MRAppMaster

hive 报 找不到或无法加载主类 org.apache.hadoop.mapreduce.v2.app.MRAppMaster

解决办法:关键需要配置两个配置:mapred-site.xml 和 yarn-site.xml下面配置hadoop classpath。先运行shell命令:hadoop classpath添加一个配...

Kubernetes网络模型与CNI网络插件

Kubernetes网络模型与CNI网络插件

在 Flannel 的网络插件中,容器跨主机网络的两种实现方法:UDP 和 VXLAN。它们有一个共性,就是用户的容器都连接在 docker0 网桥上。而网络插件则在宿主机上创建了一个特殊的设备(UD...

Haproxy配置负载均衡

yum安装haproxy如果后面要配置高可用,和keepalived配合使用更佳。yum install haproxy修改配置文件设置impala和ldap的负载均衡(Impala Daemon分布...

Linux进程的几种状态之R、S、D、T、Z

Linux是一个多用户,多任务的系统,可以同时运行多个用户的多个程序,就必然会产生很多的进程,而每个进程会有不同的状态。1.R(TASK_RUNNING),可执行状态&运行状态(在run_qu...

发表评论    

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