MySQL 添加列报错处理

梦莱2年前技术文章1231

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


相关文章

stress压测工具

1、stress 概述stress是一个linux的压力测试工具,主要用来模拟系统负载较高时的场景,用于对系统的CPU、IO、内存、负载、磁盘等进行压力测试2、安装yum install -y epe...

8.0 新特性-Redo 配置的变化

8.0 新特性-Redo 配置的变化

说明本篇文章将介绍 MySQL Redo 日志的作用,及需要关注的参数,在 5.7、8.0 Redo 的变化。1. Redo 日志介绍1.1. Redo 有什么作用为了取得更好的读写性能,InnoDB...

MySQL性能优化(六)优化or条件

MySQL性能优化(六)优化or条件

优化器是数据库中非常核心,又非常复杂的一个组件。有的SQL,优化器选择的执行计划并不是最优的,通过改写SQL,可以帮助优化器找到最优的执行计划。where条件中的or子句,是比较容易出问题的一个场景。...

kafka安全认证与授权

kafka安全认证与授权一、SASL、SSL、ACL介绍1.SASL鉴权协议,主要用来保证客户端登录服务器的时候,传输的鉴权数据的安全性,SASL是对用户名和密码加解密用的 2.SSL是一种间于传输层...

Yarn调度器对比

1)Hadoop调度器重要分为三类:FIFO 、Capacity Scheduler(容量调度器)和Fair Sceduler(公平调度器)。Apache默认的资源调度器是容量调度器;CDH...

Python functools 模块

1、reduce 方法reduce 方法,顾名思义就是减少,map reduce 应用:大数据语法: reduce(function, sequence[, initial]) -> value...

发表评论    

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