作家
登录

如何从MongoDB迁移到MySQL?这有现成经验!

作者: 来源: 2017-10-20 11:05:20 阅读 我要评论

end 
  •  
  • model.save! validate: false 
  •  
  • rescue Exception => e 
  •  
  • STDERR.puts e 
  •  
  • raise e 
  •  
  • end 
  •  
  • STDOUT.puts “#{index}/#{models_count} ” if (counter % 1000).zero? 
  •  
  • end 
  •  
  • end 
  •  
  • end 
  •  
  • end  
  • 大年夜关系到文档

    固然这篇文┞仿的重点是大年夜 MongoDB 迁徙到 MySQL,但作者照样想简单提一下大年夜 MySQL 到 MongoDB 的迁徙,如不雅我们仅仅是将 MySQL 中的全部数据导入到 MongoDB 中其实是一间比较简单的工作,个中最重要的原因就是 MySQL 支撑的数据类型是 MongoDB 的子集:

    在迁徙的过程中可以将 MySQL 中的全部数据以 csv 的格局导出,然后再将所有 csv 格局的数据应用 mongoimport 全部导入到 MongoDB 中:

    1. $ mysqldump -u<username> -p<password
    2.  
    3. -T <output_directory> 
    4.  
    5. –fields-terminated-by ‘,’ 
    6.  
    7. –fields-enclosed-by ‘”‘ 
    8.  
    9. –fields-escaped-by ” 
    10.  
    11. no-create-info <database_name> 
    12.  
    13. $ mongoimport –db <database_name> –collection <collection_name> 
    14.  
    15. –type csv 
    16.  
    17. –file <data.csv> 
    18.  
    19. –headerline  

    全部过不雅察起来只须要两个敕令,异常简单,但比及你真要去做时你会碰到异常多的问题,作者没有过大年夜 MySQL 或者其它关系型数据库迁徙到 MongoDB 的经验,然则 Google 上相干的材料特别多,所以这老是一个有无数前人踩过坑的问题,而前人的经验也可以或许赞助我们节俭很多时光。

    应用 csv 的方法导出数据在绝大年夜多半的情况都不会出现问题,但如不雅数据库中的某些文档中存储的是富文本,那么固然在导出数据时不会出现问题,最终导入时可能出现一些比较奇怪的缺点。

    大年夜文档到关系

    比拟于大年夜 MySQL 到 MongoDB 的迁徙,反向的迁徙就麻烦了不止一倍,这主如果因为 MongoDB 中的很多半据类型和集合之间的关系袈溱 MySQL 中都并不存在,比如嵌入式的数据构造、数组和哈希等集合类型、多对多关系的实现,很多的问题都不是仅仅能经由过程数据上的迁徙解决的,我们须要在对数据进行迁徙之前先对部分数据构造进行重构,本文中的后半部分会介绍须要处理的数据构造和逻辑。

    当我们预备将数据库彻底迁徙到 MySQL 之前,须要做一些预备工作,将最后迁徙所须要的工作尽可能地削减,包管停机的时光不会太长,预备工作的目标就是尽量祛除工程中复杂的数据构造。

    数据的预处理

    在进行迁徙之前要做很多预备工作,第一件工作是要把所有嵌入的数据构造改成非嵌入式的数据构造:


      推荐阅读

      如何选择硬盘:SSD硬盘vsHDD硬盘

    总之,HDD硬盘和SSD硬盘各有本身的市场。而兼具SSD硬盘和HDD硬盘的机能和特点的mSATASSD设备和混淆驱动器是花费者寻求分砂茨?的更浩揭捉?择。 沙龙晃荡 | 去哪儿、陌陌、ThoughtWorks在主动化运维中的>>>详细阅读


    本文标题:如何从MongoDB迁移到MySQL?这有现成经验!

    地址:http://www.17bianji.com/lsqh/38066.html

    关键词: 探索发现

    乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

    网友点评
    自媒体专栏

    评论

    热度

    精彩导读
    栏目ID=71的表不存在(操作类型=0)