欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySql导入CSV文件或制表符分割的文件

程序员文章站 2023-01-11 07:51:07
有时候我们会有这样的需求,需要把一些数据从别的库导入到另外的一个库中,而这些数据是用csv文件存放的。对于mysql数据库我们有两种方式:一种是用命令来导入,另一种是很多的...

有时候我们会有这样的需求,需要把一些数据从别的库导入到另外的一个库中,而这些数据是用csv文件存放的。对于mysql数据库我们有两种方式:一种是用命令来导入,另一种是很多的mysql客户端(如heidisql、sequel pro)为我们提供了这样的功能。下面我们来分别介绍着两种导入方式。

mysql命令导入

准备工作:

先建一个表:

建表语句如下:

create table `city_china` (
 `id` int(11) not null auto_increment comment '主键',
 `ename` varchar(12) null default null comment '省的简称',
 `ecityname` varchar(12) null default null comment '市的名称',
 `ccityname` varchar(12) null default null comment '市的中文',
 primary key (`id`)
)
collate='utf8_general_ci'
engine=innodb
auto_increment=81
;

准备要导入的csv文件:

首先我们新建一个excel文件,内容如下:

MySql导入CSV文件或制表符分割的文件

然后我们把excel文件转换为csv文件。操作为:文件---->另存为:

MySql导入CSV文件或制表符分割的文件MySql导入CSV文件或制表符分割的文件

注意:字段默认是用逗号来进行分割的。文档中主键可以空着不填,另外顺序要和数据库中字段的顺序保持一致。另外我们注意到:我们的数据库的编码格式是utf-8,我们的csv文件中是含有中文的,如果我们直接导入的 话,中文可能会导入不到数据库了。我们需要把csv文件的编码格式变为utf-8.转换csv格式我们有一种简单的方式,csv文件是可以用记事本来编辑的。用记事本打开编辑,然后另存为的时候选择一些编码格式就ok了。

导入命令

复制代码 代码如下:
load data infile 'd:\\document\\download\\test0142.csv' into table city_china fields terminated by ',' enclosed by '"' lines terminated by '\n' ignore 1 rows ;

load data infile 后面跟的是要导入的文件路径,into table 表名 fields terminated by 分割字段方式(这里默认是逗号,可以更改为其他的分割方式)enclosed by 分号分割,默认就行 lines terminated by 换行 ignore 1 rows 忽略第一行(本例中第一行为数据库中对应的字段,如果你的文件中第一行就是数据的话,就不要忽略第一行了)。

mysql客户端

这里我用的是heidisql客户端为例。连接上数据库之后,在左上边的菜单上(两个小人的左边)有这样一个按钮,如图:

MySql导入CSV文件或制表符分割的文件

点击,会弹出如下页面:

MySql导入CSV文件或制表符分割的文件

点击导入就ok。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。