学习 MySQL中导入 导出CSV

来源:互联网 发布:淘宝网民族风帽子 编辑:程序博客网 时间:2024/04/24 01:21

学习 MySQL中导入 导出CSV

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';   
[sql] view plaincopy
  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';   
[sql] view plaincopy
  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'   
[sql] view plaincopy
  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.    
[sql] view plaincopy
  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  

本文链接:http://blog.csdn.net/kongxx/article/details/7051439

MySQL自己提供了导入导出数据库的工具,但有时我们需要仅仅导入导出单个表的数据,比如导入导出CSV文件,此时可以使用MySQL自动的命令来做导入导出工作。


导出语法如下:

[plain] view plaincopyprint?
  1. SELECT * FROM [TABLE]  
  2. INTO OUTFILE '[FILE]';  
  3. 或者  
  4. SELECT * FROM [TABLE]  
  5. INTO OUTFILE '[FILE]'  
  6. FIELDS TERMINATED BY ','   
  7. OPTIONALLY ENCLOSED BY '"'   
  8. LINES TERMINATED BY '\n';  
下边是一个具体的导出的例子:
[plain] view plaincopyprint?
  1. SELECT * FROM mytable   
  2. INTO OUTFILE '/tmp/mytable.csv'  
  3. FIELDS TERMINATED BY ','   
  4. OPTIONALLY ENCLOSED BY '"'   
  5. LINES TERMINATED BY '\n';  

导入语法如下:

[plain] view plaincopyprint?
  1. LOAD DATA INFILE '[FILE]'  
  2. INTO TABLE [TABLE];  
  3. 或者  
  4. LOAD DATA INFILE '[FILE]'  
  5. INTO TABLE [TABLE]  
  6. FIELDS TERMINATED BY ','   
  7. OPTIONALLY ENCLOSED BY '"'   
  8. LINES TERMINATED BY '\n';  
下边是一个具体的导入的例子:
[plain] view plaincopyprint?
  1. LOAD DATA INFILE '/tmp/mytable.csv'   
  2. INTO TABLE mytable   
  3. FIELDS TERMINATED BY ','   
  4. OPTIONALLY ENCLOSED BY '"'   
  5. LINES TERMINATED BY '\n';  

0 0
原创粉丝点击