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