mongodb转mysql思路_将MongoDB数据转到MySQL中

前言

我们有个老项目,以前用户量很大,现在没多少了,但是架构是以前的,aws的mongodb集群一个月的费用也不少,所以计划重构代码,我这边负责的是将mongodb的数据转到mysql,用过java写过转换程序,速度太慢,停服时间只有两个小时,尝试过阿里的datax,同步还可以,还是达不到我们的需求,于是我使用了mongodb导出csv文件到mysql导入的方法

mongo导出csv文件

我刚开始用的办法是mongoexport,速度还可以,可是开始导入到mysql的时候才发现这种办法真的是差点意思! 为什么呢,mongoexport不能指定delimiter,它是标准的分隔符”,””。这就让我们很苦恼,因为mongodb的很多表里有对象属性,比如有个content字段,它的值是{”name”:”zhanghua”,”age”:18}。注意到了么,这里有个”,” 而mysql的判断是不是另外的字段就是通过,来做的split。

万般无奈下(主要没找到好的方法),我决定写一个node脚本来来将mongodb里面的数据转换成我想要的csv格式

将csv文件导入到mysql中

这个就简单,但是需要改的设置也不少,说一下最重要语句就行了

我本地测试用的datagrip,在dg上用这个直接测就行了

5a0b7fcc3c8253c0f43feaa55a173d43.png

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值