use*_*987 7 mongodb meteor mongodb-query
我用它来做一个upsert:
Articles.update(
{ title: title },
{
title: title,
parent: type
},
{ upsert: true },
function(res) {
return console.log(res);
}
);
console.log(needToGetID);
Run Code Online (Sandbox Code Playgroud)
现在我需要获取已更新或插入的文档的_id.我以为我可以通过回调得到它,但是res未定义.我假设只有一个由查询定义的唯一文档.
更新
忘记提到我正在使用流星......
目的.update()是基本上只是"更新"匹配的文档(因为"多"也可以在这里应用)并完成它,因此特别考虑到这个"可以"应用于多个文档然后返回这样的信息在这个行动方面,这真的没有意义.
但是,如果您的目的是修改单个"特定文档",那么.findOneAndUpdate()假设您使用的是猫鼬,则该方法将适用:
Articles.findOneAndUpdate(
{ title: title },
{
title: title,
parent: type
},
{ upsert: true, new: true },
function(res) {
return console.log(res);
}
);
Run Code Online (Sandbox Code Playgroud)
还要注意new: true哪个是重要的,因为没有它,默认行为是在语句修改之前"返回"文档.
无论如何,由于此处的返回是匹配和修改的文档,_id因此响应中存在该值和任何其他值.
使用meteor,你可以添加一个插件来启用.findAndModify()哪个是root方法:
meteor add fongandrew:find-and-modify
Run Code Online (Sandbox Code Playgroud)
然后在代码中:
Articles.findAndModify(
{
"query": { title: title },
"update": {
title: title,
parent: type
},
"upsert": true,
"new": true
},
function(res) {
return console.log(res);
}
);
Run Code Online (Sandbox Code Playgroud)
请注意,您还应该使用$set运算符,因为没有它,更改基本上"覆盖"目标文档:
Articles.findAndModify(
{
"query": { "title": title },
"update": {
"$set": {
"parent": type
}
},
"upsert": true,
"new": true
},
function(res) {
return console.log(res);
}
);
Run Code Online (Sandbox Code Playgroud)