python导入mongodb数据_Python将数据从MongoDB导入MySQL_MYSQL_Think tank

本文介绍了如何使用Python和MySQL Shell将MongoDB中的JSON数据导入MySQL。首先,通过mongoexport将MongoDB数据导出到JSON,然后利用MySQL Shell的import_json功能,配合Python脚本将JSON导入MySQL,同时讨论了导入过程中的BSON ObjectId转换和数据结构差异。
摘要由CSDN通过智能技术生成

MySQL Shell 8.0.13(GA)引入了一项新功能,允许您轻松地将JSON文档导入MySQL。这篇新功能的基础知识在之前的博客文章中有所描述。在本博客中,我们将提供有关此功能的更多详细信息,重点关注许多人感兴趣的实际用例:如何将MongoDB中的JSON数据导入MySQL。可以应用相同的“配方”将数据从其他文档存储数据库导入MySQL,只要它们能够生成或导出数据到JSON即可。

无论出于何种原因,迁移到不同数据库产品的任务不应掉以轻心,并且在某些情况下可能非常复杂。在其他方面,它取决于数据库服务器的数量及其在系统中的组织(单一服务器Vs复杂复制拓扑),数据大小,执行此任务的要求和可用资源。应定义全面详细的计划以确保成功,包括执行所有必需步骤和相应的操作/工具。

注意:在开始迁移生产数据库系统之前,强烈建议您首先迁移数据样本并测试最终结果,以确保它符合您的期望和要求。这也可以让您测试迁移计划。

每个迁移计划都是不同的,并且特定于每个用例,但都可能包括常见步骤,例如更新应用程序以使用新数据库,以及导出/导入数据库数据。MySQL Shell中用于导入JSON数据的新功能有助于我们以更简单的方式执行此步骤。让我们看看在实践中如何使用Python将数据从MongoDB导入MySQL。

将数据从MongoDB导出到JSON

MongoDB允许您将所有数据导出到JSON,但它生成MongoDB Extended JSON的严格模式表示。幸运的是,MySQL Shell JSON导入功能允许您使用选项'convertBsonOid'轻松转换BSON ObjectId类型。

注意:如果您的数据包含除ObjectId之外的其他BSON类型,它们以严格模式表示(例如,BinData,Date,Timestamp,NumberLong,NumberDecimal等),那么您可能需要手动将这些类型的转换处理为基础您的要求(例如,在导入/导出过程中使用您自己的自定义转换脚本,或在应用程序级别转换它们)。有关BJSON类型及其在严格模式下的表示的更多信息,请参阅:BSON数据类型和关联表示。

您需要做的第一件事是将所有MongoDB数据导出到JSON文档。例如,假设您在“测试”数据库中有两个集合,名称为:restaurants和neighboors。您可以使用以下说明将MongoDB数据导出到JSON文档(每个集合一个文件):

1

2

3

4

5

6

7$ mongoexport --db test --collection restaurants --out restaurants_m

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值