我使用mysqlimport来摄取csv文件。
这是我使用的命令:
mysqlimport --ignore-lines=1 --fields-terminated-by=, --columns=$COLUMNS --lines-terminated-by="\n" \
--verbose --local --fields-enclosed-by='"' --host=$HOST --port=$PORT \
--user=$USERNAME --password=$PASSWORD ${DATABASE} $FILE_PATH
在我开始这个过程之前,我截断了表,它没有任何唯一索引。
源文件有7288362条记录(开始时我认为csv行可能包含换行符。我做了检查,但文件中没有引用的新行字符。)
然而,当mysqlimport完成时,它说"记录:7288300已删除:0跳过:0警告:43730142"。
当我登录mysql并从MyTable中选择计数(*)时,它也给了我7288300。
有什么想法吗?
谢谢!
答案 0 :(得分:0)
我的csv文件中有这种行:
1345235,62,"Theme From \Shaft\""""",,Chris Davis & Kim Waters,,,,,,5,0,,,,,,,,,,2016-10-28,,,,2016-10-28,,Y,,,,,,0,2016-10-28 09:09:39
那里的多引号引起了一个问题。当我添加--fields-escaped-by=''
时,它有效。