MySQL 添加列报错处理

梦莱2年前技术文章845

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


相关文章

元数据管理

元数据管理

一、元数据概念元数据是关于数据的数据,主要用于跟踪、分类和分析。元数据大致定义为提供有关其他内容的信息的数据,但不提供有关数据实质的信息,例如图片本身或文本消息的内容。它可以帮助用户理解数据的含义,对...

DBMS_SESSION包跟踪10046

注意:DBMS_SESSION包:只能跟踪当前会话,不能指定会话DBMS_SESSION.SET_SQL_TRACE=ALTER SESSION SET SQL_TRACE; =ALTER SESSI...

Docker 网络介绍

一、Docker 网络docker网络主要是解决容器联网问题,也是我们使用容器中最重要的一个环节,如果容器没有网络则无法向网络中提供服务。网络管理命令:docker network[root@zutu...

Shell中单引号和双引号区别

1)在/home/atguigu/bin创建一个test.sh文件[atguigu@hadoop102 bin]$ vim test.sh在文件中添加如下内容#!/bin/bashdo_date=$1...

Phoenix SQLLine快速使用

Phoenix SQLLine快速使用

1、启动在Phoenix主目录下bin文件夹中,执行以下命令:bin/sqlline.py master其中master为Zookeeper中的节点,如果有多个节点,中间使用逗号分开。执行该命令后,客...

sql_mode参数

sql_mode参数

一、参数含义sql_mode是个很容易被忽视的变量,其本身主要就是一种语法校验规则 ,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入。二、常用值含义1、ONLY_FUL...

发表评论    

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