我想将请求发送到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对象与新的对象进行交换。
答案 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/