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

原创 2016年08月30日 10:07:42

有时候我们会有这样的需求,需要把一些数据从别的库导入到另外的一个库中,而这些数据是用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文件,内容如下:
然后我们把excel文件转换为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客户端为例。连接上数据库之后,在左上边的菜单上(两个小人的左边)有这样一个按钮,如图:
点击,会弹出如下页面:

点击导入就OK。




版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

MySQL 去除字段中的换行和回车符

UPDATE SMS_PROVINCE SET PROVINCENAME = REPLACE(REPLACE(PROVINCENAME, CHAR(10),''), CHAR(13),''); ...
  • gyanp
  • gyanp
  • 2011-12-28 16:29
  • 19874

csv 文件导入 MySQL 遇到的转义字符问题

csv 文件导入 MySQL 遇到的转义字符问题提示 "invalid utf8 character string" 实为文本数据中默认转义字符造成的问题。

csv格式的文件数据导入mysql指定的表中方法

1、将csv文件数据用逗号分割保存 2、将csv文件通过类似ultraedit工具打开csv文件将文件格式改为utf-8 3、csv文件中的数据要和表中字段顺序对应上 4、通过sqlyog工具选...

以CSV文件导入MySQL的批量数据插入操作之Java操作

以CSV文件导入MySQL的批量数据插入操作之Java操作

MYSQL 分享:split最快速度将字符串进行分割以表的方式进行展示

USE test; CREATE TABLE test.Num ( xh INT PRIMARY KEY ); -- 创建数字辅助表 SET @i = 0; INSERT INT...

MySQL数据入库时特殊字符处理

在一个字符串中,如果某个序列具有特殊的含义,每个序列以反斜线符号 (“\”)开头,称为转义字符。 MySQL 识别下列转义字符: \0一个 ASCII 0 (NUL) 字符。\'一个 ASCII 3...

【php】 向mysql中插入数据使用了制表符,取数据时怎么办

插入数据的部分代码如下: $moderators = implode("\t", $members); C::t('forum_forumfield')->update($fid, array('m...

更改csv默认分隔符

对于带分隔符的文本文件,可以在“文本导入向导”的步骤 2 中将分隔符从制表符更改为其他字符。在步骤 2 中,还可以更改处理连续分隔符(如连续引号)的方式。 有关使用“文本导入向导”的详细信息,请参阅文...

MySQL _LOAD DATA 导入 csv 文件到数据库表操作日志

1.说明LOAD DATA INFILE语句用于高速地从一个文本文件中读取行,并装入一个表中。文件名称必须为一个文字字符串。标准语法:LOAD DATA LOCAL INFILE 'data.txt'...

使用Navicat for MySql导入.CSV文件

1、创建一个数据库,右键点击表,选择导入向导。 2、选择导入的数据文件格式,下一步。 3、选择你的.csv文件,注意编码格式,要与你的文件编码格式一样,不然出现乱码...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)