码迷,mamicode.com
首页 > 数据库 > 详细

MySQL – 导出数据成csv

时间:2015-08-29 09:45:23      阅读:215      评论:0      收藏:0      [点我收藏+]

标签:

方案有很多种,我这里简单说一下:

1.  into outfile

1 SELECT * FROM mytable  
2 INTO OUTFILE /tmp/mytable.csv  
3 FIELDS TERMINATED BY ,  
4 OPTIONALLY ENCLOSED BY "  
5 LINES TERMINATED BY \n;

在我使用过程中发现一个特别严重问题,这里面不能插入查询条件,比如where这些,也就是说只能整表导出,不知道是不是我的写法有问题,有知道朋友请给我留言。

第二个问题是,outfile的路径一定要有写权限,我们mysql的进程权限一般是mysql用户,因此最好导出到/tmp目录下面。

2. 通过结合sed

mysql -uroot test -e "select ip from server where a.name like ‘%abc%‘"  -N -s | sed -e s/^/"/g;s/$/"\n/g; > /tmp/test.csv

这里首先使用mysql命令的-e参数来执行sql语句,然后通过-N来去掉输出结果中列名,-s去掉输出结果中的各种划线。

然后使用sed命令输出结果中所有相关数据进行替换,其中替换了三处,1.在行首增加“,在行尾增加”和换行,在每个字段之间增加”,”来分隔。

3. 通过mysqldump来实现

mysqldump -u username -p -t  -T/path/to/directory dbname table_name --fields-terminated-by=‘,‘

和1的方案差不多吧。

 

就当是一个笔记吧

MySQL – 导出数据成csv

标签:

原文地址:http://www.cnblogs.com/huangjacky/p/4768386.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!