MySQL导入导出csv文件

MySQL导入导出csv文件

###导出csv文件语句结构

select * from j_position_provice
into outfile 'C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/xx.csv'
FIELDS TERMINATED BY ','   
OPTIONALLY ENCLOSED BY '"'   
LINES TERMINATED BY '\r\n' 

###导入scv文件语句结构

load data infile 'C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/output2.csv' 
into table a_test 
FIELDS TERMINATED BY ','   
OPTIONALLY ENCLOSED BY ''   
LINES TERMINATED BY '\r\n'(code_id,name);

###注意事项
1.secute-file-priv
: ERROR 1290 (HY000): The MySQL server is running with the –secure-file-priv option so it cannot execute this statement

在导出csv的时候,有可能会抛出如上的错误,这是由于导出的时候文件夹的权限不够。
**方法一:**我们可以在命令行或者工具下查询路径的权限,语法如下

show variables like '%secure%'

安全查询结果
找到secure_file_priv的路径,并在我们SELECT语句的INTO OUTFILE字句中使用该目录

SELECT * FROM xxxx WHERE XXX

INTO OUTFILE ‘/var/lib/mysql-files/report.csv’
FIELDS TERMINATED BY ‘,’
ENCLOSED BY ‘"’
LINES TERMINATED BY ‘\r\n’

**方法二:**查找可操控安全文件夹位置
找到C:\ProgramData\MySQL\MySQL Server 5.7\my.ini这个文件并打开,我们可以发现,在MySQL5.6以后,secure-file-priv这个新版本的MySQL Server中添加了一个默认值:
secure-file-priv="C:/ProgramData/MySQL/MySQL Server 5.6/Uploads"
如果你处于非生产环境,可以尝试修改,修改之后记得重启MySQL服务,此时,我们将所需要导入的文件放到这个目录下,就可以进行导入,我安装的是MySQl Server 5.7版本,所以我对应的导入语句如下:

select * from j_position_provice
into outfile ‘C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/xx.csv’
FIELDS TERMINATED BY ‘,’
OPTIONALLY ENCLOSED BY ‘"’
LINES TERMINATED BY ‘\r\n’

2.导入文件时,文件的名称和数据库表名尽量一致
如果数据库有多个字段,而且其中有些又有没用到,可以将具体的字段写在导入语句上,好将csv的列和表字段匹配上
load data infile 'C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/a_position.csv' into table a_position 
    FIELDS TERMINATED BY ','   
    OPTIONALLY ENCLOSED BY '"'   
    LINES TERMINATED BY '\r\n'(code_id, name, parent_code_id);

最后,大家有什么不懂的或者其他需要交流的内容,也可以进入我的QQ讨论群一起讨论:654331206

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值