一、问题来源
跟着马士兵老师的教程学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版本过低,不具有本功