MySql中插入中文数据提示Data too long for column X at row n的解决

解决MySQL中文数据插入问题
本文介绍了在使用MySQL数据库过程中遇到的中文数据插入失败问题及其解决办法。通过调整客户端和结果集的编码设置,成功避免了数据过长的错误。
部署运行你感兴趣的模型镜像

一、问题来源

                 跟着马士兵老师的教程学mysql数据库的时候,在看到要求用递归输出树状结构的"蚂蚁大战大象"的部分时,我写好sql语句后先用命令 \. d:/XXX/article.sql;,提示示有两个错误。

二、初步思考

                改成和马老师教程里面一样的命令 \. D:\XXX\article.sql去执行后(盘符用大写字母;路径用\;不要最后的分号),sql文件开头的 create database bbs;use bbs;成功执行,后面的所有插入语句就都提示 ERROR 1406 (22001):data too long for column 'title' at row 1 ",用 desc article;命令查看了下表结构,title字段是varchar(11),应该没问题。

三、网上查询

                接着就上网查了下,大家都说是插入的数据是中文就会这样,原因是编码方式设置的不对,按照其中一位朋友的方法我也解决了这个问题(我安装mysql数据库的时候选择的默认编码方式是utf-8)

四、解决方法

                先在mysql命令行窗口中: show variables like '%char%';显示的编码格式都是utf8,将命令
set character_set_client=gbk;set character_set_results=gbk; (将mysql客户端编码设置为gbk,同时也将结果集results的编码设置为gbk,防止乱码)添加到sql文件里的插入数据语句 前面,在sql文件里只保留这两条语句和后面的插入数据语句,再在mysql的命令行窗口执行 \. D:\XXX\article.sql,果然插入数据成功!
再补充下, set character_set_results=gbk;的作用是让我们 查看中文字段的数据时候能看到正常的正文而不是乱码, set character_set_client=gbk;的作用是让我们在进行 插入更改这种涉及中文数据的操作的时候不再出现那个data too long的错误。
还有,这两句命令的效果只是 临时的,就是当你关闭了mysql的命令行窗口,以后重新登录进来依然会存在这方面的问题,之前的设置clint和results的字符集格式的操作相当于只在之前的那个会话中有效,这意味着你每次打开一个mysql命令行窗口操作(涉及中文数据)之前都要先运行 set character_set_client=gbk;set character_set_results=gbk;

五、附百度上查的mysql错误代码表

1005:创建表失败 
1006:创建数据库失败 
1007:数据库已存在,创建数据库失败 
1008:数据库不存在,删除数据库失败 
1009:不能删除数据库文件导致删除数据库失败 
1010:不能删除数据目录导致删除数据库失败 
1011:删除数据库文件失败 
1012:不能读取系统表中的记录 
1020:记录已被其他用户修改 
1021:硬盘剩余空间不足,请加大硬盘可用空间 
1022:关键字重复,更改记录失败 
1023:关闭时发生错误 
1024:读文件错误 
1025:更改名字时发生错误 
1026:写文件错误 
1032:记录不存在 
1036:数据表是只读的,不能对它进行修改 
1037:系统内存不足,请重启数据库或重启服务器 
1038:用于排序的内存不足,请增大排序缓冲区 
1040:已到达数据库的最大连接数,请加大数据库可用连接数 
1041:系统内存不足 
1042:无效的主机名 
1043:无效连接 
1044:当前用户没有访问数据库的权限 
1045:不能连接数据库,用户名或密码错误 
1048:字段不能为空 
1049:数据库不存在 
1050:数据表已存在 
1051:数据表不存在 
1054:字段不存在 
1064 处理控制请求时,服务出现意外情况。
1065:无效的SQL语句,SQL语句为空 
1081:不能建立Socket连接 
1114:数据表已满,不能容纳任何记录 
1116:打开的数据表太多 
1129:数据库出现异常,请重启数据库 
1130:连接数据库失败,没有连接数据库的权限 
1133:数据库用户不存在 
1141:当前用户无权访问数据库 
1142:当前用户无权访问数据表 
1143:当前用户无权访问数据表中的字段 
1146:数据表不存在 
1147:未定义用户对数据表的访问权限 
1149:SQL语句语法错误 
1158:网络错误,出现读错误,请检查网络连接状况 
1159:网络错误,读超时,请检查网络连接状况 
1160:网络错误,出现写错误,请检查网络连接状况 
1161:网络错误,写超时,请检查网络连接状况 
1062:字段值重复,入库失败 
1169:字段值重复,更新记录失败 
1177:打开数据表失败 
1180:提交事务失败 
1181:回滚事务失败 
1203:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库 
1205:加锁超时 
1211:当前用户没有创建用户的权限 
1216:外键约束检查失败,更新子表记录失败 
1217:外键约束检查失败,删除或修改主表记录失败 
1226:当前用户使用的资源已超过所允许的资源,请重启数据库或重启服务器 
1227:权限不足,您无权进行此操作 
1235:MySQL版本过低,不具有本功




您可能感兴趣的与本文相关的镜像

Langchain-Chatchat

Langchain-Chatchat

AI应用
Langchain

Langchain-Chatchat 是一个基于 ChatGLM 等大语言模型和 Langchain 应用框架实现的开源项目,旨在构建一个可以离线部署的本地知识库问答系统。它通过检索增强生成 (RAG) 的方法,让用户能够以自然语言与本地文件、数据库或搜索引擎进行交互,并支持多种大模型和向量数据库的集成,以及提供 WebUI 和 API 服务

MySQL 中 `BLOB` 类型用于存储较大的二进制数据,例如图片、文件或加密信息。当插入数据时出现 `Data too long for column 'authentication' at row 1` 错误,即使该列使用的是 `BLOB` 类型,可能的原因包括列的实际类型限制、字符集设置或 SQL 模式的影响。 ### 数据类型限制 `BLOB` 类型有多个子类型,包括 `TINYBLOB`、`BLOB`、`MEDIUMBLOB` 和 `LONGBLOB`,它们分别支持不同的最大存储容量。例如: - `TINYBLOB`: 最大 255 字节 - `BLOB`: 最大 65,535 字节 - `MEDIUMBLOB`: 最大 16,777,215 字节 - `LONGBLOB`: 最大 4,294,967,295 字节 如果插入数据大小超过当前列的数据类型限制,则会触发 `Data too long` 错误。可以通过以下 SQL 语句查看当前列的定义: ```sql DESCRIBE your_table_name; ``` 如果确认数据大小超过当前列的容量,可以通过 `ALTER TABLE` 语句修改列的数据类型,例如: ```sql ALTER TABLE your_table_name MODIFY authentication LONGBLOB; ``` ### 字符集与编码影响 如果 `authentication` 列被错误地定义为字符类型(如 `VARCHAR` 或 `TEXT`)并使用了多字节字符集(如 `utf8mb4`),插入的二进制数据可能会因编码转换而占用更多字节,导致超出长度限制。确保该列的定义为 `BLOB` 类型,并且没有指定字符集[^1]。 ### SQL 模式影响 MySQLSQL 模式决定了数据插入和更新时的严格程度。如果启用了严格模式(如 `STRICT_TRANS_TABLES`),任何超过列长度限制的插入操作都会直接失败,而不是自动截断数据。可以通过以下命令检查当前 SQL 模式: ```sql SELECT @@sql_mode; ``` 如果需要允许数据自动截断,可以调整 SQL 模式,例如: ```sql SET GLOBAL sql_mode = 'NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'; ``` ### 在线 DDL 操作 MySQL 支持使用在线 DDL(ALGORITHM=INPLACE)来修改表结构,包括更改列的数据类型。这意味着在修改 `authentication` 列的类型时,不会阻塞表的读写操作,适用于高并发环境下的结构变更[^1]。 ### 示例操作 以下是一个完整的修改列类型并插入数据的示例: ```sql -- 查看当前表结构 DESCRIBE users; -- 修改列的类型为 LONGBLOB ALTER TABLE users MODIFY authentication LONGBLOB; -- 插入较大二进制数据 INSERT INTO users (authentication) VALUES (LOAD_FILE('/path/to/large_file.bin')); ``` ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值