Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL CSV导入

MySQL将CSV文件快速导入MySQL中的实现

作者:何为xl

本文主要介绍了MySQL将CSV文件快速导入MySQL中的实现,主要包括navicat、workbench等软件中的导入向导手动导入或使用load data infile命令导入,感兴趣的可以了解一下

一般来说,将csv文件导入mysql数据库有两种办法:

前者速度较慢,适合数据量比较小的时候,而对于大文件,我们需要使用命令行导入。

方法一:使用navicat等软件的导入向导

打开安装好的Navicat Premium,连接数据库。

成功连接后如下图:

创建数据库

点击“方向导入”

选择需要导入的文件类型

选择需要导入文件的路径

查看导入的表结构是否正确

导入成功

如果出现中文乱码

解决方案:

将原来存储在桌面上的 OrderData 文件通过 Notepad++ 进行转码,格式为 UTF-8 点击OrderDaTa.csv, 右键用 Notepad++ 打开,修改编码。

重新导入数据

点击开始按钮,数据导入中…

方法二:命令行导入(LOAD DATA INFILE SQL)

准备工作

在mysql中将表结构先建好,包括字段名及类型等

假设你的 CSV 文件包含图书信息,分为 ISBN、Title、Author 和 ListPrice 字段。要创建这样一个表,你需要执行这样的命令。

CREATE TABLE BooksCSV (
    ISBN VARCHAR(255) NULL,
    title VARCHAR(255) NULL,
    author VARCHAR(255) NULL,
    ListPrice VARCHAR(255) NULL
);

两个建议:

使用如下命令查看是否允许从外部路径导入文件

show variables like '%secure%';

如果结果显示secure_file_priv=‘’,即空字符串,则无需改动;如果secure_file_priv=null,则需要在mysql的配置文件my.ini中添加如下行secure_file_priv=‘’,之后重启mysql服务。

使用如下命令查看是否允许本地导入

show variables like 'local_infile';

如果结果是off,则改使用如下命令改为on

set global local_infile=on;

导入文件

使用如下命令导入文件。注意:文件路径不能有中文!!

load data local infile 'file_path' # 文件路径
into table daily_price             # 表名
character set utf8                 # 编码
fields terminated by ','           # 分隔符
lines terminated by '\r\n'         # 换行符,windows下是\r\n
ignore 1 lines;                    # 忽略第一行,因为表头已建好

其他有关load data infile的细节可在此地址查询

https://www.mysqlzh.com/doc/126/255.html

到此这篇关于MySQL将CSV文件快速导入MySQL中的实现的文章就介绍到这了,更多相关MySQL CSV导入MySQL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文