MySQL 查询结果保存为CSV文件

馋奶兔 提交于 2021-02-12 09:16:31

点击上方“IT共享之家”,进行关注

回复“资料”可获赠IT学习福利

MySQL支持将查询结果直接导出为文本格式,格式如下:

into outfile ‘导出的目录和文件名’                  指定导出的目录和文件名

fields terminated by ‘字段间分隔符’            定义字段间的分隔符

optionally enclosed by ‘字段包围符’           定义包围字段的字符(数值型字段无效)

lines terminated by ‘行间分隔符’                定义每行的分隔符

举个栗子:

select * from [表名] where [字段名] ='条件'into outfile 'c:/test.csv' fields terminated by ',' optionally enclosed  by  '"' lines terminated by '\r\n'; 

执行后,会把指定表中记录数据导出到c:/test.csv文件中。每个字段以,(逗号)分隔,字段内容是字符串的以”(双引号)包围,每条记录使用\r\n换行。如图所示


如果导出的过程中出现:

the MySQL server is running with the --secure-file-priv option so it cannot execute this statement

首先了解一下secure-file-priv特性:

secure-file-priv参数是用来限制LOAD DATA, SELECT ... OUTFILE, and LOAD_FILE()传到哪个指定目录的。
ure_file_priv的值为null ,表示限制mysqld 不允许导入|导出
当secure_file_priv的值为具体目录 ,表示限制mysqld 的导入/导出只能发生在具体目录下
当secure_file_priv的值没有具体值时,表示不对mysqld 的导入|导出做限制
如何查看secure-file-priv参数的值:

show global variables ike '%secure%' ;

解决问题:
windows下:修改my.ini (一般在mysql的安装路径下,如果没有my.ini文件参考官方说明)在[mysqld]下方加入secure-file-priv=你的路径(路径中\要以/来代替否则会出错)
然后重启mysql(参考命令)

再查询secure-file-priv

往期精彩文章推荐:

看完本文有收获?请转发分享给更多的人

IT共享之家

入群请在微信后台回复【学习】

在公众号后台回复下列关键词可以免费获取相应的学习资料:

Python3、Python基础、Python进阶、网络爬虫 、书籍、

自然语言处理、数据分析、机器学习、数据结构、

大数据、服务器、Spark、Redis、C++、C、

php、mysql、java、Android、其他

本文分享自微信公众号 - IT共享之家(info-share)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!