MySQL学习笔记:MySQL ERROR 1300 (HY000): Invalid utf8 character string

本文介绍了解决MySQL在导入包含中文的数据文件时遇到的错误情况,特别是当字符串中出现特殊转义字符时的问题。通过调整数据文件内容并去除特定转义字符,成功实现了数据的正确导入。

       刚开始使用MySQL,版本为5.7.11(windows),今天导入本地的一个数据文件时,报错ERROR 1300 (HY000): Invalid utf8 character string '高中'。网上搜解决办法,在设置编码都为UTF-8的情况下,再次导入还是报相同错误。此时猜测可能是文件的问题,于是用“记事本”打开文件,搜索报错的“高中”,结果发现有“高中\中专”的记录,中文字符串中含有英文字符“\",尝试去掉“\”,保存后再次load data local infile "E:/mysql/mydata" into table mytable;导入成功!

       验证是否中英混搭导致load数据失败:
建一张test表测试是否是中英混搭
mysql> create table test1
    -> (a varchar(32)
    -> )
    -> ;
test.txt
Chinese
中文
中文;Chinese
test1.txt
中文\Chinese
test2.txt
中文\中文
导入test.txt
mysql> load data local infile "E:/mysql/test.txt" into table test1;
Query OK, 3 rows affected (0.08 sec)
Records: 3  Deleted: 0  Skipped: 0  Warnings: 0
导入test1.txt
mysql> load data local infile "E:/201506-win/test1.txt" into table test1;
Query OK, 1 row affected (0.08 sec)
Records: 1  Deleted: 0  Skipped: 0  Warnings: 0
导入test2.txt
mysql> load data local infile "E:/201506-win/test2.txt" into table test1;
ERROR 1300 (HY000): Invalid utf8 character string: '中文'
     经过这几个测试发现,中英文字符不存在问题,可以正常插入,导致失败的原因是转义字符“\”后面为中文的问题,像“中文\中文”这样,后面为英文,即“中文\Chinese”是可以正常使用的,插入的记录“\”也没有显示。





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值