查询数据库数据并写入到文件中的优化方案

有限制条件的大招:

第一步:执行完以下sql,会自动的在mysql服务器对应的机器上生成所要的文件

SELECT ... FROM TABLE_xxx where ... INTOOUTFILE"/tmp/xxx/xxx"FIELDSTERMINATEDBY','OPTIONALLYENCLOSEDBY''LINESTERMINATEDBY'\n';

第二步:将上面sql中的导出文件的地址“/tmp/xxx/xxx”里的文件,用文件流下载下来。

此种方式有约束条件:对于那些严格遵守规范的大公司来说,mysql数据库的机器上的文件是不允许应用去拿的,只能从sftp或者专门的文件服务器上去拿,故拿不到该文件,方案不可行。


注:将第一步的sql生成的文件的数据导入数据库表中的方案:

LOAD DATA INFILE "/tmp/xxx/xxx" INTO TABLE table_name FIELDS TERMINATED BY ',' ;

注意:如果导出时用到了FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '' LINES TERMINATED BY '\n'语句,那么LODA时也要加上同样的分隔限制语句。还要注意编码问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值