使用update()获取受影响文档的ID

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未定义.我假设只有一个由查询定义的唯一文档.

更新

忘记提到我正在使用流星......

Bla*_*ven 6

目的.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)