【发布时间】:2015-03-13 23:52:07
【问题描述】:
我正在创建一个 Web 应用程序,它将与以 JSON 格式返回数据的 REST API 进行通信。当然,当我将数据提取到恰好是 PostgreSql 的数据库中时,该数据可以转换为关系数据。但我正在考虑改用 MongoDb,因为使用 JSON 对于 MongoDb 来说更自然。
你的想法,我应该使用 MongoDb 来代替这个原因吗?
【问题讨论】:
标签: json mongodb postgresql rest
我正在创建一个 Web 应用程序,它将与以 JSON 格式返回数据的 REST API 进行通信。当然,当我将数据提取到恰好是 PostgreSql 的数据库中时,该数据可以转换为关系数据。但我正在考虑改用 MongoDb,因为使用 JSON 对于 MongoDb 来说更自然。
你的想法,我应该使用 MongoDb 来代替这个原因吗?
【问题讨论】:
标签: json mongodb postgresql rest
最适合您的选择可能取决于几个因素:
MongoDB 的水平扩展性非常好,这意味着如果您要频繁轮询 API 并将大量数据插入数据库,那么实现分片并在另一台服务器上启动另一个 Mongo 实例相对容易。 Difference between scaling horizontally and vertically for databases
将 JSON 数据插入 MongoDB 可能比将其转换为关系格式并可能进行多次插入(假设 JSON 格式正确)您可以只进行一次插入更简单。或者使用 mongoimport 一次导入多个 JSON 文档。如果 API 数据经常更改,例如新列,那么在关系数据库中,您将不得不使用 ALTER TABLE 创建列,而在 MongoDB 中,它将只存储 JSON 文档。
如果您想了解有关 MongoDB 的更多信息,他们会提供免费的在线课程。这些课程为期 7 周,每周他们都会发布新的视频讲座和新的作业,这需要几个小时才能完成。 https://university.mongodb.com/courses/catalog
【讨论】:
如果您在 json 结构中有任何数据字段聚合,则有一个用例值得检查。这是一个可能需要对 RDBMS 或处于高级状态(可能是 OLAP 存储)的粘性的用例。
【讨论】: