MySQL中导入 导出CSV

原创 2015年11月18日 10:21:46

MySQL中导出CSV格式数据的SQL语句样本如下:

Sql代码  收藏代码
  1. select * from test_info   
  2. into outfile '/tmp/test.csv'   
  3. fields terminated by ',' optionally enclosed by '"' escaped by '"'   
  4. lines terminated by '\r\n';   
  1. select * from test_info   
  2. into outfile '/tmp/test.csv'   
  3. fields terminated by ',' optionally enclosed by '"' escaped by '"'   
  4. lines terminated by '\r\n';   

MySQL中导入CSV格式数据的SQL语句样本如下:

Sql代码  收藏代码
  1. load data infile '/tmp/test.csv'   
  2. into table test_info    
  3. fields terminated by ','  optionally enclosed by '"' escaped by '"'   
  4. lines terminated by '\r\n';   
  1. load data infile '/tmp/test.csv'   
  2. into table test_info    
  3. fields terminated by ','  optionally enclosed by '"' escaped by '"'   
  4. lines terminated by '\r\n';   

里面最关键的部分就是格式参数

Sql代码  收藏代码
  1. fields terminated by ',' optionally enclosed by '"' escaped by '"'   
  2. lines terminated by '\r\n'   
  1. fields terminated by ',' optionally enclosed by '"' escaped by '"'   
  2. lines terminated by '\r\n'   

这个参数是根据RFC4180文档设置的,该文档全称Common Format and MIME Type for Comma-Separated Values (CSV) Files,其中详细描述了CSV格式,其要点包括:

(1)字段之间以逗号分隔,数据行之间以\r\n分隔;

(2)字符串以半角双引号包围,字符串本身的双引号用两个双引号表示。

 

文件:test_csv.sql

Sql代码  收藏代码
  1. use test;  
  2.   
  3. create table test_info (  
  4.     id  integer not null,  
  5.     content varchar(64) not null,  
  6.     primary key (id)  
  7. );  
  8.   
  9. delete from test_info;  
  10.   
  11. insert into test_info values (2010, 'hello, line  
  12. suped  
  13. seped  
  14. "  
  15. end'  
  16. );  
  17.   
  18. select * from test_info;  
  19.   
  20. select * from test_info into outfile '/tmp/test.csv' fields terminated by ',' optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';  
  21.   
  22. delete from test_info;  
  23.   
  24. load data infile '/tmp/test.csv' into table test_info  fields terminated by ','  optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';  
  25.   
  26. select * from test_info;  
  27.   
  28.    
  1. use test;  
  2.   
  3. create table test_info (  
  4.     id  integer not null,  
  5.     content varchar(64) not null,  
  6.     primary key (id)  
  7. );  
  8.   
  9. delete from test_info;  
  10.   
  11. insert into test_info values (2010, 'hello, line  
  12. suped  
  13. seped  
  14. "  
  15. end'  
  16. );  
  17.   
  18. select * from test_info;  
  19.   
  20. select * from test_info into outfile '/tmp/test.csv' fields terminated by ',' optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';  
  21.   
  22. delete from test_info;  
  23.   
  24. load data infile '/tmp/test.csv' into table test_info  fields terminated by ','  optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';  
  25.   
  26. select * from test_info;  
  27.   
  28.    

 

文件:test.csv

Text代码  收藏代码
  1. 2010,"hello, line  
  2. suped  
  3. seped  
  4. ""  
  5. end"  
[Text] view plaincopy
  1. 2010,"hello, line  
  2. suped  
  3. seped  
  4. ""  
  5. end"  

 

在Linux下如果经常要进行这样的导入导出操作,当然最好与Shell脚本结合起来,为了避免每次都要写格式参数,可以把这个串保存在变量中,如下所示:(文件mysql.sh)

Bash代码  收藏代码
  1. #!/bin/sh  
  2.   
  3.   
  4. # Copyright (c) 2010 codingstandards. All rights reserved.  
  5. # file: mysql.sh  
  6. # description: Bash中操作MySQL数据库  
  7. # license: LGPL  
  8. # author: codingstandards  
  9. # email: codingstandards@gmail.com  
  10. # version: 1.0  
  11. # date: 2010.02.28  
  12.   
  13.   
  14. # MySQL中导入导出数据时,使用CSV格式时的命令行参数  
  15. # 在导出数据时使用:select ... from ... [where ...] into outfile '/tmp/data.csv' $MYSQL_CSV_FORMAT;  
  16. # 在导入数据时使用:load data infile '/tmp/data.csv' into table ... $MYSQL_CSV_FORMAT;  
  17. # CSV标准文档:RFC 4180  
  18. MYSQL_CSV_FORMAT="fields terminated by ',' optionally enclosed by '\"' escaped by '\"' lines terminated by '\r\n'"  
 

使用示例如下:(文件test_mysql_csv.sh)

Bash代码  收藏代码
  1. #!/bin/sh  
  2.   
  3. . /opt/shtools/commons/mysql.sh  
  4.   
  5. # MYSQL_CSV_FORMAT="fields terminated by ',' optionally enclosed by '\"' escaped by '\"' lines terminated by '\r\n'"  
  6. echo "MYSQL_CSV_FORMAT=$MYSQL_CSV_FORMAT"  
  7.   
  8. rm /tmp/test.csv  
  9.   
  10. mysql -p --default-character-set=gbk -t --verbose test <<EOF  
  11.   
  12. use test;  
  13.   
  14. create table if not exists test_info (  
  15.     id  integer not null,  
  16.     content varchar(64) not null,  
  17.     primary key (id)  
  18. );  
  19.   
  20. delete from test_info;  
  21.   
  22. insert into test_info values (2010, 'hello, line  
  23. suped  
  24. seped  
  25. "  
  26. end'  
  27. );  
  28.   
  29. select * from test_info;  
  30.   
  31. -- select * from test_info into outfile '/tmp/test.csv' fields terminated by ',' optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';  
  32. select * from test_info into outfile '/tmp/test.csv' $MYSQL_CSV_FORMAT;  
  33.   
  34. delete from test_info;  
  35.   
  36. -- load data infile '/tmp/test.csv' into table test_info fields terminated by ','  optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';  
  37. load data infile '/tmp/test.csv' into table test_info $MYSQL_CSV_FORMAT;  
  38.   
  39. select * from test_info;  
  40.   
  41.   
  42. EOF  
  43.   
  44. echo "===== content in /tmp/test.csv ====="  
  45. cat /tmp/test.csv  
 
版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

mysql导入导出csv

项目开发中,很多时候要将外部CSV文件导入到数据库中或者将数据导出为CSV文件,那么具体该如何实现呢?本文将使用PHP并结合mysql,实现了CSV格式数据的导入和导出功能。 下载源码 ...

学习 MySQL中导入 导出CSV

学习 MySQL中导入 导出CSV

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

学习 MySQL中导入 导出CSV

MySQL中导出CSV格式数据的SQL语句样本如下: Sql代码   select * from test_info   into outfile '/tmp/test.csv...

php CSV表格导入导出

我们先准备mysql数据表,假设项目中有一张记录学生信息的表student,并有id,name,sex,age分别记录学生的姓名、性别、年龄等信息。 CREATE TABLE `student` (...

导入导出mysql表数据到csv

导出: SELECT 字段名 INTO OUTFILE '路径' FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATE...
  • ssyan
  • ssyan
  • 2011-04-14 16:02
  • 3102

mysql导入导出csv文件

问题:为什么要导入导出为csv文件呢? (1)所谓大数据处理,仅仅关心某些列的数据,而非整个表结构,这些数据就需要保存为csv通用的存储格式,不仅可以在widows下作为文本文件进行处理;也可以...

Java读csv文件,结合iframe上传csv文件,解决乱码问题

说说问题在哪: 上传csv文件到service层以后,file.getInputStream(),这样得到的是字节流,要一行一行的读文件内容,就得转换,然后问题就卡在了这里。 InputStreamR...

mysql 数据导入导出命令

备份一个数据库.mysqldump -uroot -p123456 mysql > mysql_backup.sql 这里备份了database mysql的结构和数据,生成的sql文件不会有创建da...

mysql大数据表导入导出

客户那一台流量分析设备需要给更换成新设备,但要求保留之前的流量分析数据,查看了一下流量分析表情况,发现有几张分钟粒度的数据表数据量达到几亿条以上,数据库使用的是mysql,使用mysql 的导入导出工...

mysql 数据库导入导出(本地以及远程)

一、先进入mysql的安装路径: 一、导入和导出本地数据库    导出:    1、先运行cmd,cd到mysql安装目录中的bin文件夹    2、mysqldump -u root-p 数据库...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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