背景
最近做个独立项目,需要从一个第三方平台的 API 获取订单数据,但是该平台的 API 只能返回类似下面格式的数据
{
data: {
count: 100000,
items: [
{
_id: "575d74b6427b9e8f40d5b619",
num_iid: 1,
name: "0",
__v: 0
},
{
_id: "575d74b6427b9e8f40d5b61a",
num_iid: 2,
name: "1",
__v: 0
}]
}
}
上面这个数据是我测试生成的,其中 num_iid 是该平台唯一的,可以关联到商品记录,现在我需要把这个数据同步到我的系统上进行处理,那么这里面有这几个问题:
1. 第三方平台的数据可能随时更新,比如订单的状态
2. 该平台并不提供更新订阅的接口,所以订单是否更新了,我的系统并不知道
3. 该平台除了这个接口,还有一个根据订单 id 获取订单详情的接口
我的系统需要满足:
1. 数据需要和该平台同步
2. 数据的同步可以有半天的延时
3. 目前可以选择最简单的处理,在系统运行过程中去选择优化的办法
技术选择
NodeJS, MongoDB
解决办法
初步是选择了递归来处理,从