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。




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

heidisql导入txt、csv等文件时乱码问题解决方案

昨天使用heidisql连接实验室服务器的数据库,想导入自己爬的一些txt、csv数据,导入文件时出现了乱码问题,特此记录。 (想要heidisql安装包的可留下邮箱)...
  • m0_37788308
  • m0_37788308
  • 2017年10月27日 17:52
  • 190

HeidiSQL工具导出导入MySQL数据

有时候,为了数据方便导出导入SQL,我们可以借助一定的工具,方便我们队
  • u014655105
  • u014655105
  • 2014年10月29日 18:48
  • 12582

MySql 中导入txt文本文件数据1

其实 的这个问题是mysql中的一个核心问题,既mysql数据的备份和恢复 可以使用三种方式 1.使用sql语句导入导出 2.使用mysqldump 和mysqlimport 工具 3.直接c...
  • junmoxie
  • junmoxie
  • 2012年08月06日 13:25
  • 2315

mysql导入csv文件出错解决办法

将*.csv文件导入mysql可使用LOAD DATA INFILE, 概要写法: Load data in file  对于本地文件,使用 load data local infile 'D:...
  • u012422446
  • u012422446
  • 2016年03月30日 00:53
  • 4200

mysql 用load data 导入数据时,数据被截断问题

在 MySQL 中使用 load data infile 命令导入数据文件到 MySQL 数据库中的时候,如果遇到 MySQL 错误:“ERROR 1261 (01000)” ,则很可能是由于数据文件...
  • stormlovetao
  • stormlovetao
  • 2012年02月16日 16:12
  • 2194

csv文件导入Mysql

本篇博客主要讲将csv文件导入Mysql的方法(使用命令行)。 Step1:csv文件的准备 1、首先看一下我本次导入的数据,比较简单; (1)在数据库中首先建立了一个名为“test”的数据库...
  • quiet_girl
  • quiet_girl
  • 2017年05月08日 22:16
  • 12521

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

插入数据的部分代码如下: $moderators = implode("\t", $members); C::t('forum_forumfield')->update($fid, array('m...
  • yangmingysc
  • yangmingysc
  • 2013年03月13日 00:39
  • 1461

mysql 解决去除空格,左右空格和制表符以及回车的方法

最近导表的时候,发现有些数据多了一些空格和制表的东西, 用了一个sql就解决了。 先声明下 CHAR(9)=>水平制表符 char(10)=>换行建 char(13)=>回车键 具体用法如下:  UP...
  • saygood999
  • saygood999
  • 2017年11月30日 10:52
  • 155

wex5 实战 HeidiSQL 导入Excel数据

一 前言          以前没做过大东西,突然客户说,我给你个数据,你部署到云上。我想,很简单啊,随口答应了。       悲剧发生了,客发给我的,居然是一张excel表!!!       ...
  • qq_27727681
  • qq_27727681
  • 2016年12月30日 16:48
  • 2326

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

1.说明LOAD DATA INFILE语句用于高速地从一个文本文件中读取行,并装入一个表中。文件名称必须为一个文字字符串。标准语法:LOAD DATA LOCAL INFILE 'data.txt'...
  • csdn_yasin
  • csdn_yasin
  • 2016年07月11日 10:46
  • 1894
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MySql导入CSV文件或制表符分割的文件
举报原因:
原因补充:

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