Mysql 报Row size too large 65535 的原因及解决方法

当我们在 MySQL 中创建一张数据表时,如果某个字段的数据类型是 text 或 blob,那么在该表的行的最大大小不能大于 65535 字节,否则就会报 "Row size too large" 的错误。

这个错误的原因是,MySQL 默认的 InnoDB 存储引擎的单行限制大小为 65535 字节,如果一条记录长度超过了这个值,则 MySQL 就无法存储这条记录。

解决这个问题的方法有以下三种:

1. 将表的类型换成 MyISAM

MyISAM 存储引擎类型的表单行限制大小是 65536 字节,可将表的类型更改为 MyISAM,以达成错误消除的目的。

ALTER TABLE `table_name` ENGINE = MyISAM;

2. 调整字段类型

通过调整表中的字段类型来减少记录长度。

示例 1:将 text 类型的字段修改成 varchar 类型的字段,这样可以占用更少空间,同时避免了 "Row size too large" 的错误。

ALTER TABLE `table_name` MODIFY `text_col` VARCHAR(2048);

示例 2:将 BLOB 类型的字段修改成 MEDIUMBLOB 类型的字段,这样可以缩小字段的长度,使其符合单行大小限制要求:

ALTER TABLE `table_name` MODIFY `blob_col` MEDIUMBLOB;

3. 将数据拆分成多个字段或表

如果单行大小超过了 65535 字节,可以考虑将原数据表拆分成多张表或多个字段。例如,将一个大的 text 字段拆分成多个 text 字段,或将一个大的数据库表分割成多个表。

示例:将数据表中的字段分成两张表:

CREATE TABLE `table_name_1` (
  `id` INT(11) PRIMARY KEY AUTO_INCREMENT,
  `col1` TEXT,
  `col2` TEXT
);

CREATE TABLE `table_name_2` (
  `id` INT(11) PRIMARY KEY AUTO_INCREMENT,
  `col3` TEXT,
  `col4` TEXT
);

以上是解决 "Row size too large" 的错误的几种方法,我们可以根据具体情况选择合适的方法进行处理。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Mysql 报Row size too large 65535 的原因及解决方法 - Python技术站

(0)
上一篇 2023年5月18日
下一篇 2023年5月18日

相关文章

  • mysql导入sql文件出错的解决方法

    下面是详细讲解”mysql导入sql文件出错的解决方法”的完整攻略,包括错误信息的分析、解决方法以及示例说明: 错误信息分析 当我们使用mysql命令导入sql文件时,可能会遇到以下类型的错误信息: ERROR 1064 (42000): You have an error in your SQL syntax; ERROR 1062 (23000): Du…

    MySQL 2023年5月18日
    00
  • Mysql5.5 InnoDB存储引擎配置和优化

    下面是“Mysql5.5 InnoDB存储引擎配置和优化”的完整攻略: Mysql5.5 InnoDB存储引擎配置和优化 什么是InnoDB存储引擎 InnoDB是Mysql数据库的一种存储引擎,它是一个完整的事务安全的存储引擎,支持外键约束和提交、回滚事务等功能。相对于MyISAM存储引擎,InnoDB更加稳定,支持更多的操作。 InnoDB存储引擎默认配…

    MySQL 2023年5月19日
    00
  • MySQL游标(Cursor)的定义及使用方法详解

    MySQL游标(Cursor)是一种可在数据库中使用的数据结构,它被用于遍历结果集中的所有行并进行特定操作。游标通常用于存储过程和函数中,当需要一行一行地获取结果集中的数据时,它就变得非常有用了。 游标通常与SELECT语句一起使用,以便在结果集中获取数据。游标用于遍历结果集中的记录,并将结果集中的数据一行一行地存储或处理。游标顺序访问结果集中的每一行,并将…

    MySQL 2023年3月10日
    00
  • mysql 常见命令及参数说明

    mysql数据库使用总结 本文主要记录一些mysql日常使用的命令,供以后查询。 1.更改root密码 mysqladmin -uroot password ‘yourpassword’ 2.远程登陆mysql服务器 mysql -uroot -p -h192.168.137.10 -P3306 3.查询数据库 show databases; 4.进入某个数…

    MySQL 2023年4月12日
    00
  • MYSQL安装配置文件my-small.ini、my-medium.ini、my-large.ini、my-huge.ini文件的作用 my-small.ini、my-medium.ini、my-large.ini、my-huge.ini文件的作用

      安装完mysql之后或者是下载的免安装版解压之后,默认是没有my.ini文件的.但是,有几个类似的文件,如my-small.ini、my-medium.ini、my-large.ini、my-huge.ini。这几个文件是mysql针对不同的应用推荐的不同的配置信息;但这些配置只有放到my.ini中才会被应用。其中:1、my-small.ini是为了小型…

    MySQL 2023年4月12日
    00
  • Navicat连接MySQL提示1045错误解决(重置MySQL密码)

    下面就是“Navicat连接MySQL提示1045错误解决(重置MySQL密码)”的完整攻略。 问题描述 在使用Navicat连接MySQL数据库时,出现了错误提示:“1045 – Access denied for user ‘root’@’localhost’ (using password: YES) ”,这个错误很可能是由于MySQL管理员密码错误或…

    MySQL 2023年5月18日
    00
  • MySQL 8.0 对 limit 的优化技巧

    MySQL 8.0 对 limit 的优化技巧主要包括两方面内容:使用优化器新特性和合理选择limit参数。 优化器新特性 MySQL 8.0 引入了新的优化器特性“Cost Model”,会动态计算执行单元的成本,从而有效地提高查询速度,对 limit 的优化也得到了加强。在使用 limit 时,可以通过设置 MYSQL_OPTIMIZE_LIMIT_OF…

    MySQL 2023年5月19日
    00
  • 开启bin-log日志mysql报错的解决方法

    以下是“开启bin-log日志mysql报错的解决方法”的完整攻略: 1. 问题描述 在MySQL数据库中开启bin-log日志时,有时会遇到如下报错信息: ERROR 29 (HY000): File ‘filename’ not found (Errcode: 13 – Permission denied) 2. 原因分析 根据报错信息,可以看出问题出在…

    MySQL 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部