如何将数据附加到mongodb中的对象属性

时间:2017-12-26 07:48:40

标签: javascript node.js mongodb mongoose

我想将请求发送到mongodb数据库。 例如,我有这个对象:

{
  id:"1",
  requestType : {
     "api1" : {count:12,firstTime:12},
     "api2" : {count:6,firstTime:18}
   }
}

通过" id"获取数据后我想将另一行追加到" requestType"例如" api3":{count:56,firstTime:11}。 我的预期目标是:

{
   id:"1",
   requestType : {
       "api1" : {count:12,firstTime:12},
       "api2" : {count:6,firstTime:18},
       "api3":{count:56,firstTime:11}
    }
 }

目前我正在通过mongoose使用此查询:

apiAttemptsModel.findOneAndUpdate(query, {
    $set: {
        requestType : {"api3":{count:56,firstTime:11}}
    }
}, {upsert: true, new: true}, function (err, row) {
    if (err) {
        callback('err is ' + err)
    } else {
        callback(row);
    }
});

但是这段代码会将旧的requestType对象与新的对象进行交换。

2 个答案:

答案 0 :(得分:0)

试试这个:

apiAttemptsModel.findOneAndUpdate(query, {
    $set: {
        "requestType.api3" : {count:56, firstTime:11}
    }
}, {upsert: true, new: true}, function (err, row) {
    if (err) {
        callback('err is ' + err)
    } else {
        callback(row);
    }
});

顺便说一句,这不是使用回调的正确方法 通常使用以下签名调用节点中的回调: function(error, data) -
因此,在调用callback(row);时,此方法的用户可能会遇到错误,就像您在第5行上使用回调函数一样。
当没有发生错误时,第一个参数通常是null

此外,调用callback('err is ' + err)只会保留错误消息并丢弃其堆栈跟踪,因为错误被“转换”为字符串。

我将您的代码转换为:

apiAttemptsModel.findOneAndUpdate(query, {
    $set: {
        "requestType.api3" : {count:56, firstTime:11}
    }
}, {upsert: true, new: true}, function (err, row) {
    if (err) {
        callback(err)
    } else {
        callback(null, row);
    }
});

答案 1 :(得分:0)

设置心烦为false。这将更新文档,但如果文档尚不存在则不会创建文档。

https://docs.mongodb.com/manual/reference/method/db.collection.update/