mysql2csv 和 csv2mysql 工具

在这里提供了两个使用 .csv 格式 的简单的 MySQL 数据库的导数据工具。csv 格式可以很容易地生成和解析,而且,也可以很容易地使用办公软件把 .csv 格式转换为 .xls/.xlsx 格式,或者把 .xls/.xlsx 格式转换为 .csv 格式的文件。

  • mysql2csv - 将 MySQL 的数据导出为 csv 格式的文件。
  • csv2mysql - 将 csv 格式的文件的数据导入到 MySQL 数据库。

编译代码

在编译代码之前,如果你用的是 yum,那么请先确定软件包 mysql-devel 已经安装在你的系统中,才能使用 mysql 的头文件 mysql/mysql.h ,以及和库文件 libmysqlclient.a 或者 libmysqlclient.so

使用下面的两行命令一编译这两个工具:

g++ mysql2csv.cpp -omysql2csv -g -L/usr/lib64/mysql/  -lmysqlclient
g++ csv2mysql.cpp -ocsv2mysql -g -L/usr/lib64/mysql/ -lmysqlclient

演示

首先,创建一个测试用的数据库,建立初始的数据:

[roxma@VM_6_207_centos mysql2csv]$ mysql -uroot --password="" --default-character-set=utf8
... mysql> create database csv_test default charset=utf8;
Query OK, 1 row affected (0.02 sec) mysql> use csv_test;
Database changed
mysql> create table test(id int primary key, value1 varchar(1024))engine=innodb;
Query OK, 0 rows affected (0.08 sec) mysql> show create table test \G
*************************** 1. row ***************************
Table: test
Create Table: CREATE TABLE `test` (
`id` int(11) NOT NULL,
`value1` varchar(1024) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec) mysql> insert into test (id,value1) values(1,"hello"),(2, 'comma , double quotes " '),(3,NULL);
Query OK, 3 rows affected (0.00 sec)
Records: 3 Duplicates: 0 Warnings: 0 mysql> select * from test;
+----+--------------------------+
| id | value1 |
+----+--------------------------+
| 1 | hello |
| 2 | comma , double quotes " |
| 3 | NULL |
+----+--------------------------+
3 rows in set (0.00 sec)

导出 MySQL 的数据到 .csv 文件:

[roxma@VM_6_207_centos mysql2csv]$ ./mysql2csv host="127.0.0.1" port="3306"  db="csv_test" user="root" passwd="" charset="utf8" execute="select * from test" > data.csv
host=127.0.0.1
port=3306
db=csv_test
user=root
passwd=
charset=utf8
execute=select * from test [roxma@VM_6_207_centos mysql2csv]$ cat data.csv
id,value1
1,hello
2,"comma , double quotes "" "
3,NULL

导入 .csv 文件的数据到 MySQL:

[roxma@VM_6_207_centos mysql2csv]$ ./csv2mysql host="127.0.0.1" port="3306" db="csv_test" user="root" passwd="" charset="utf8" execute="insert into test set id=?id+3, value1=?value1" input="data.csv"
host=127.0.0.1
port=3306
db=csv_test
user=root
passwd=
charset=utf8
execute=insert into test set id=?id+3, value1=?value1
input=data.csv
3 rows executed. [roxma@VM_6_207_centos mysql2csv]$ mysql -uroot --password="" --default-character-set=utf8 --database="csv_test" -e"select * from test"
+----+--------------------------+
| id | value1 |
+----+--------------------------+
| 1 | hello |
| 2 | comma , double quotes " |
| 3 | NULL |
| 4 | hello |
| 5 | comma , double quotes " |
| 6 | NULL |
+----+--------------------------+

支持的工具选项

<thread>
<tr>
<th colspan="3">通用选项</th>
</tr>
</thread> <tbody>
<tr>
<td>host</td> <td>MySQL server 的机器名</td> <td>127.0.0.1</td>
</tr>
<tr>
<td>port</td> <td>MySQL 连接的目标端口</td> <td>3306</td>
</tr>
<tr>
<td>user</td> <td>MySQL 用户名</td> <td>root</td>
</tr>
<tr>
<td>passwd</td> <td>MySQL 用户的密码</td> <td></td>
</tr>
<tr>
<td>charset</td> <td>MySQL 连续使用的字符编码</td> <td>utf8</td>
</tr>
<tr>
<td>db</td> <td>使用的 MySQL 数据库名。相当于 use db 命令。</td> <td></td>
</tr>
</tbody> <thread>
<tr>
<th colspan="3">mysql2csv 选项</th>
</tr>
</thread>
<tbody>
<tr>
<td>execute</td> <td>需要执行的 MySQL 查询命令</td> <td></td>
</tr>
<tr>
<td>null_cell_value</td> <td>当对应的值NULL时,使用这个字符串替换到表格中。</td> <td>NULL</td>
</tr>
<tr>
<td>output</td> <td>生成的 csv 文件的文件名。如果这个选项为空,则文件 的内容会被输出到 stdout。</td> <td></td>
</tr>
</tbody> <thread>
<tr>
<th colspan="3">csv2mysql 选项</th>
</tr>
</thread>
<tbody>
<tr>
<td>execute</td> <td>需要执行的 MySQL 指令</td> <td></td>
</tr>
<tr>
<td>warning_as_error</td> <td>如果为个选项为1,那么在执行 MySQL 语句的过程中如果出现任何 warning,都会被视为错误,程序直接终止退出。</td> <td>1</td>
</tr>
<tr>
<td>input</td> <td>输入的 csv 文件的文件名。如果这个选项为空,则程序从 stdin 中读取数据。</td> <td></td>
</tr>
</tbody>
选项 描述 默认值

代码下载

https://github.com/roxma/cpp_learn/tree/master/tools/mysql2csv

mysql2csv 和 csv2mysql 工具的更多相关文章

  1. Unity3d入门 - 关于unity工具的熟悉

    上周由于工作内容较多,花在unity上学习的时间不多,但总归还是学习了一些东西,内容如下: .1 根据相关的教程在mac上安装了unity. .2 学习了unity的主要的工具分布和对应工具的相关的功 ...

  2. 细说前端自动化打包工具--webpack

    背景 记得2004年的时候,互联网开发就是做网页,那时也没有前端和后端的区分,有时一个网站就是一些纯静态的html,通过链接组织在一起.用过Dreamweaver的都知道,做网页就像用word编辑文档 ...

  3. 应用工具 .NET Portability Analyzer 分析迁移dotnet core

    大多数开发人员更喜欢一次性编写好业务逻辑代码,以后再重用这些代码.与构建不同的应用以面向多个平台相比,这种方法更加容易.如果您创建与 .NET Core 兼容的.NET 标准库,那么现在比以往任何时候 ...

  4. .NetCore中的日志(2)集成第三方日志工具

    .NetCore中的日志(2)集成第三方日志工具 0x00 在.NetCore的Logging组件中集成NLog 上一篇讨论了.NetCore中日志框架的结构,这一篇讨论一下.NetCore的Logg ...

  5. dll文件32位64位检测工具以及Windows文件夹SysWow64的坑

    自从操作系统升级到64位以后,就要不断的需要面对32位.64位的问题.相信有很多人并不是很清楚32位程序与64位程序的区别,以及Program Files (x86),Program Files的区别 ...

  6. Java基础Map接口+Collections工具类

    1.Map中我们主要讲两个接口 HashMap  与   LinkedHashMap (1)其中LinkedHashMap是有序的  怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...

  7. 渗透测试工具BurpSuite做网站的安全测试(基础版)

    渗透测试工具BurpSuite做网站的安全测试(基础版) 版权声明:本文为博主原创文章,未经博主允许不得转载. 学习网址: https://t0data.gitbooks.io/burpsuite/c ...

  8. CorelDRAW X8 如何破解激活(附国际版安装包+激活工具) 2016-12-15

    之前有位搞平面的好友“小瘦”说CDR X8无法破解,只能用X7.呃……呃……呃……好像是的 其实CDR8难激活主要在于一个点“没有离线激活了,只可以在线激活”,逆天不是专供逆向的,当然没能力去破解,这 ...

  9. Web Api 入门实战 (快速入门+工具使用+不依赖IIS)

    平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html 屁话我也就不多说了,什么简介的也省了,直接简单概括+demo ...

随机推荐

  1. BASE64编码规则及C#实现

    一.编码规则      Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码.它将需要编码的数据拆分成字节数组.以3个字节为一组.按顺序排列24位数据,再把这24位数据分成4组 ...

  2. ☀【Zepto】

    http://zeptojs.com/ https://github.com/madrobby/zepto Zepto 中文手册 http://www.360weboy.com/handbook/ze ...

  3. 【转】Beyond Compare for Mac中文版震撼来袭!-- 不错

    原文网址:http://mt.sohu.com/20160329/n442685522.shtml Beyond Compare想必大家都知道,它是一个专业级的一个文件对比工具,由于工作原因,我们会经 ...

  4. 原生APP与移动Web App的比较

    中国手机网民已超4.5亿,智能机用户超过3.8亿,中国移动互联网市场产值已超过712.5亿元,手机营销是未来必然趋势,而App恰恰是这个趋势下的一个强有力的营销工具: App已有两个主要的方向:原生A ...

  5. 找出Java进程中大量消耗CPU

    原文:https://github.com/oldratlee/useful-shells useful-shells 把平时有用的手动操作做成脚本,这样可以便捷的使用. show-busy-java ...

  6. Datatable转换成List实体对象列表 几个实例

    一, /// <summary> /// 将Datatable转换为List集合 /// </summary> /// <typeparam name="T&q ...

  7. asp.net基础

    这篇主要讲述以下基础知识: Request对象 Response对象 Server对象 Cookie对象 Application对象 ViewState对象 <%%>与<%=%> ...

  8. 【HTML】Intermediate1:Span&Div

    1.HTML is all bout applying meaning to content. The span & div tags apply no meaning at all=mean ...

  9. Java笔记(十九)……多线程

    概述 进程: 是一个正在执行中的程序 每一个进程执行都有一个执行顺序,该执行顺序是一个执行路径,或者叫一个控制单元 线程: 就是进程中的一个独立的控制单元,线程在控制着进程的执行 一个进程中至少有一个 ...

  10. linux进程,作业,守护进程,进程间同步

    ps axj命令查看系统中的进程.参数a表示不仅列当前用户的进程,也列出所有其他用户的进程,参数x表示不仅列有控制终端的进程,也列出所有无控制终端的进程,参数j表示列出与作业控制相关的信息: 凡是TP ...