如何使用Node.js猫鼬删除文档?


291
FBFriendModel.find({
    id: 333
}, function (err, docs) {
    docs.remove(); //Remove all the documents that match!
});

以上似乎不起作用。记录仍然存在。

有人可以修复吗?

Answers:


489

如果您不想迭代,请尝试FBFriendModel.find({ id:333 }).remove( callback );FBFriendModel.find({ id:333 }).remove().exec();

mongoose.model.find返回一个具有功能查询remove

Mongoose v5.5.3的更新- remove()现在已弃用。使用deleteOne()deleteMany()findOneAndDelete() instead.


3
是否运行删除前/删除后的中间件?(某些模型方法绕过文档中间件,我不确定这是否是其中之一,文档尚不清楚)
hunterloftis 2013年

12
我想@hunterloftis已经解决了这个问题,但是对于其他人来说,答案是“否”,这将不会在单个文档上运行前/后中间件。
number1311407

似乎很多其他答案都提到了.exec()这一点,但是根本没有。是否.exec()需要使用它是否有副作用?
DanH 2014年

文档很清楚(也许已经更新了),它绕过了中间件-请参阅mongoosejs.com/docs/middleware.html的底部-因此请小心,使用此方法可能会导致严重的难以跟踪的问题。
杰德·沃森

1
好答案!回调的参数是什么?
k88074

299

更新:猫鼬版本(5.5.3)

不建议使用remove(),而可以使用deleteOne(),deleteMany()或bulkWrite()代替。

从那时起,"mongoose": ">=2.7.1"您可以直接使用.remove()方法删除文档,而不是先查找文档然后再删除文档,这对我来说似乎更有效且更易于维护。

参见示例:

Model.remove({ _id: req.body.id }, function(err) {
    if (!err) {
            message.type = 'notification!';
    }
    else {
            message.type = 'error';
    }
});

更新:

从mongoose开始3.8.1,有几种方法可让您直接删除文档,例如:

  • remove
  • findByIdAndRemove
  • findOneAndRemove

有关更多信息,请参考mongoose API文档


13
正如对其他答案的其他评论所指出的那样,这绕过了在架构上定义的中间件,这确实很危险。因此,只有在您了解会产生的影响时才使用它。有关更多信息,请参见mongoosejs.com/docs/middleware.html
Jed Watson

2
仅作记录,直到现在我一直在使用它们而没有任何副作用,可以肯定的是,我没有在项目中使用任何中间件:)
diosney 2014年

8
remove(query)如果您不小心通过,可能会清空整个收藏集query = {}。因此,我希望findOneAndRemove(query)只删除一个文档。
joeytwiddle

1
还要注意,这不返回查询,因此也不返回承诺。你不能Model.remove({ _id: 'whatever' }).exec().then(...)
大卫

48

docs是一系列文档。所以它没有mongooseModel.remove()方法

您可以分别迭代和删除数组中的每个文档。

或-由于看起来您是通过(可能)唯一的id使用findOne来查找文档的- 而不是find


5
看到此答案假定使用的是猫鼬的旧版本,我真的不反对有人更改接受的答案。
mtkopone 2014年

实际上,这是最好的方法之一,因为它可以正确调用在模式上定义的中间件-请参阅mongoosejs.com/docs/middleware.html。如果不在应用程序中不使用中间件,则应仅使用其他方法,然后要格外小心。
杰德·沃森

41

从3.8.1版开始,这对我来说是最好的:

MyModel.findOneAndRemove({field: 'newValue'}, function(err){...});

而且它只需要一个数据库调用。假设您不执行任何remove搜索和删除操作,请使用此功能。


1
只要您不需要执行pre 'remove'操作,它就可以正常工作。
Daniel Kmak

32

简单地做

FBFriendModel.remove().exec();

1
简单有效。
Rich Apodaca 2013年

1
这会返回一个承诺吗?如果是这样,则在解决Promise时定义了什么对象?
肯尼·沃登

@KennyWorden的有效途径找到了答案- > mongoosejs.com/docs/api.html然后搜索你想要什么,但前面加上“#”与您的浏览器在页面搜索如“#save”搜索和你会看到它返回了一个承诺。
杰森·塞布林

3
如果不将条件指定为删除中指定的操作,这是一个危险的答案...
blak3r

29

mongoose.model.find()返回一个也具有功能的查询对象remove()

mongoose.model.findOne()如果只想删除一个唯一的文档,也可以使用。

否则,您也可以遵循传统方法,在该方法中,首先检索文档然后将其删除。

yourModelObj.findById(id, function (err, doc) {
    if (err) {
        // handle error
    }

    doc.remove(callback); //Removes the document
})

以下是关于model对象的方法,您可以执行以下任一操作来删除文档:

yourModelObj.findOneAndRemove(conditions, options, callback)

yourModelObj.findByIdAndRemove(id, options, callback)

yourModelObj.remove(conditions, callback);

var query = Comment.remove({ _id: id });
query.exec();

22

remove()已不推荐使用。使用deleteOne()deleteMany()bulkWrite()

我使用的代码

TeleBot.deleteMany({chatID: chatID}, function (err, _) {
                if (err) {
                    return console.log(err);
                }
            });

1
老实说,这个答案需要更多的支持。它被不公平地放在桶的底部(因为它还没有获得过半的过时选票),但这是解决以下问题的唯一答案:(node:9132) DeprecationWarning: collection.remove is deprecated. Use deleteOne, deleteMany, or bulkWrite instead.
Steven Ventimiglia

18

概括地说,您可以使用:

SomeModel.find( $where, function(err,docs){
  if (err) return console.log(err);
  if (!docs || !Array.isArray(docs) || docs.length === 0) 
    return console.log('no docs found');
  docs.forEach( function (doc) {
    doc.remove();
  });
});

实现此目的的另一种方法是:

SomeModel.collection.remove( function (err) {
  if (err) throw err;
  // collection is now empty but not deleted
});

18

小心findOne并删除!

  User.findOne({name: 'Alice'}).remove().exec();

上面的代码删除了所有名为“ Alice”的用户,而不是第一个用户

顺便说一句,我更喜欢删除这样的文档:

  User.remove({...}).exec();

或提供回调并忽略exec()

  User.remove({...}, callback);


12

如果您只想删除一个对象,则可以使用

Person.findOne({_id: req.params.id}, function (error, person){
        console.log("This object will get deleted " + person);
        person.remove();

    });

在此示例中,猫鼬将根据匹配的req.params.id进行删除。


欢迎使用Stackoverflow。您的答案是此主题中多个答案的重复。另外,您应始终检查回调中的错误。
VtoCorleone '16

9

.remove()像这样工作.find()

MyModel.remove({search: criteria}, function() {
    // removed.
});

9

我更喜欢在您需要的地方使用诺言符号

Model.findOneAndRemove({_id:id})
    .then( doc => .... )

7

要删除文档,我更喜欢使用 Model.remove(conditions, [callback])

请参阅API文档以进行删除:-

http://mongoosejs.com/docs/api.html#model_Model.remove

在这种情况下,代码将是:

FBFriendModel.remove({ id : 333 }, function(err, callback){
console.log(‘Do Stuff’);
})

如果要在不等待MongoDB响应的情况下删除文档,则不要传递回调,则需要在返回的Query上调用exec

var removeQuery = FBFriendModel.remove({id : 333 });
removeQuery.exec();

6

您可以直接在remove函数中使用查询,因此:

FBFriendModel.remove({ id: 333}, function(err){});

6

您可以随时使用Mongoose内置功能:

var id = req.params.friendId; //here you pass the id
    FBFriendModel
   .findByIdAndRemove(id)
   .exec()
   .then(function(doc) {
       return doc;
    }).catch(function(error) {
       throw error;
    });

5

更新:.remove()已折旧,但仍适用于旧版本

YourSchema.remove({
    foo: req.params.foo
}, function(err, _) {
    if (err) return res.send(err)
    res.json({
        message: `deleted ${ req.params.foo }`
    })
});

不推荐使用Model.remove
Maxwell sc

2

使用remove()方法可以删除。

getLogout(data){
        return this.sessionModel
        .remove({session_id: data.sid})
        .exec()
        .then(data =>{
            return "signup successfully"
        })
    }

不推荐使用Model.remove
Maxwell sc

1
Maxwell sc,然后发出编辑请求,然后更正。我知道您是SO新手,但是修复它比评论已贬值的方法更有用。也许您下次可以建议编辑,或者自己进行编辑,并对情况有所了解...
Joshua Michael Wagoner

1

这对我有用,只需尝试以下方法:

const id = req.params.id;
      YourSchema
      .remove({_id: id})
      .exec()
      .then(result => {
        res.status(200).json({
          message: 'deleted',
          request: {
            type: 'POST',
            url: 'http://localhost:3000/yourroutes/'
          }
        })
      })
      .catch(err => {
        res.status(500).json({
          error: err
        })
      });

Model.remove已弃用
Maxwell sc

1

根据Samyak Jain的答案,我使用Async Await

let isDelete = await MODEL_NAME.deleteMany({_id:'YOUR_ID', name:'YOUR_NAME'});

0

我真的很喜欢这种在异步/等待功能的 Express / Mongoose应用程序中使用的模式:

app.delete('/:idToDelete', asyncHandler(async (req, res) => {
  const deletedItem = await YourModel
    .findByIdAndDelete(req.params.idToDelete) // This method is the nice method for deleting
    .catch(err => res.status(400).send(err.message))

  res.status(200).send(deletedItem)
}))

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.