我想发送请求到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对象与新的对象进行交换。
试试这个:
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);
}
});
将心烦设置为false。这将更新文档,但如果文档尚不存在则不会创建。
https://docs.mongodb.com/manual/reference/method/db.collection.update/