按照常规流程来进行数据批量导入,但是导入失败。可以从以下几个点检查,逐一排除失败原因。
1. excel数据另存为csv数据,数据用逗号分隔。
2. csv数据的数据编码方式是否与MySQL数据一致,比如都设置为utf-8编码。
- 检查csv数据是否是utf-8的方法:
- 在终端输入:file -s xxxxxxxx.csv
- 查看结果是否为utf-8编码,如果不是,则修改为utf-8编码。
3. csv数据中每列的顺序是否与MySQL中要导入的表中列的顺序一致,如果不一致,需要修改为一致。
- MySQL中要导入的表,这个需要自己提前在phpMyAdmin中建好。
4. 把csv的表头内容删掉,仅保留数据。
- 问题一记录:
- 双击打开第一步生成的csv文件,选中第一行表头内容删除。点击保存后关闭文件。执行第5步,此时发现报错"第一行数据错误"。
- 然后重新打开csv文件查看,发现文件格式不再是删除第一行之前的,用逗号分隔的那种形式。从而导致了导入错误。
- 这个问题目前猜测是excel转为csv后,用Excel直接双击打开,在第一行存储了看不见的格式信息,所以删除后,导致整体的格式问题。【具体原因后续再更】
- 问题二记录:
- 针对问题一中的问题,选择mac自带的文本编辑器打开csv文件,然后删除第一行内容,保存。
- 再次用excel双击打开csv文件查看,发现中文显示乱码。但是在终端输入:file -s xxxxxxxx.csv,发现当前文件仍然是utf-8编码。
- 这个问题猜测是mac自带的文本编辑器与excel在显示上的编码区别问题。【具体原因后续再更】
- 但因为文件目前仍然是utf-8编码,所以继续执行第5步,发现导入成功。(这个结果进一步推断出了问题一中的猜想可能是对的)
- 问题三记录:
- 针对问题二的实践,选择sublime文本编辑器打开问题一中提到的csv文件,然后删除第一行内容,保存。
- 再次用excel双击打开csv文件查看,未发现中文显示乱码。在终端输入:file -s xxxxxxxx.csv,发现当前文件仍然是utf-8编码。
- 此时继续执行第5步,此时发现报错"第一行数据错误"。
- (这个结果进一步推断出了问题一中的猜想可能是对的,因为sublime编辑器一般会在操作文件后保存原始格式;而mac自带的文本编辑器一般会只保存文本的值,不保存格式。)
5. 在phpMyAdmin中,"导入文件的格式" 选择第一个 "CSV";字段分隔符更改为 ","。