验证是否中英混搭导致load数据失败:
建一张test表测试是否是中英混搭
mysql> create table test1
-> (a varchar(32)
-> )
-> ;test.txt
Chinese
中文
中文;Chinese
test1.txt
中文\Chinesetest2.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.txtmysql> load data local infile "E:/201506-win/test2.txt" into table test1;
ERROR 1300 (HY000): Invalid utf8 character string: '中文'
经过这几个测试发现,中英文字符不存在问题,可以正常插入,导致失败的原因是转义字符“\”后面为中文的问题,像“中文\中文”这样,后面为英文,即“中文\Chinese”是可以正常使用的,插入的记录“\”也没有显示。
本文介绍了解决MySQL在导入包含中文的数据文件时遇到的错误情况,特别是当字符串中出现特殊转义字符时的问题。通过调整数据文件内容并去除特定转义字符,成功实现了数据的正确导入。
330

被折叠的 条评论
为什么被折叠?



