Answers:
如果您不想迭代,请尝试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.
.exec()
这一点,但是根本没有。是否.exec()
需要使用它是否有副作用?
更新:猫鼬版本(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文档。
remove(query)
如果您不小心通过,可能会清空整个收藏集query = {}
。因此,我希望findOneAndRemove(query)
只删除一个文档。
Model.remove({ _id: 'whatever' }).exec().then(...)
docs
是一系列文档。所以它没有mongooseModel.remove()
方法
您可以分别迭代和删除数组中的每个文档。
或-由于看起来您是通过(可能)唯一的id使用findOne
来查找文档的- 而不是find
。
从3.8.1版开始,这对我来说是最好的:
MyModel.findOneAndRemove({field: 'newValue'}, function(err){...});
而且它只需要一个数据库调用。假设您不执行任何remove
搜索和删除操作,请使用此功能。
pre 'remove'
操作,它就可以正常工作。
简单地做
FBFriendModel.remove().exec();
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();
remove()
已不推荐使用。使用deleteOne()
,deleteMany()
或bulkWrite()
。
我使用的代码
TeleBot.deleteMany({chatID: chatID}, function (err, _) {
if (err) {
return console.log(err);
}
});
(node:9132) DeprecationWarning: collection.remove is deprecated. Use deleteOne, deleteMany, or bulkWrite instead.
概括地说,您可以使用:
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
});
model.remove({title:'danish'}, function(err){
if(err) throw err;
});
如果您只想删除一个对象,则可以使用
Person.findOne({_id: req.params.id}, function (error, person){
console.log("This object will get deleted " + person);
person.remove();
});
在此示例中,猫鼬将根据匹配的req.params.id进行删除。
要删除文档,我更喜欢使用 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();
您可以随时使用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;
});
更新:.remove()
已折旧,但仍适用于旧版本
YourSchema.remove({
foo: req.params.foo
}, function(err, _) {
if (err) return res.send(err)
res.json({
message: `deleted ${ req.params.foo }`
})
});
使用remove()方法可以删除。
getLogout(data){
return this.sessionModel
.remove({session_id: data.sid})
.exec()
.then(data =>{
return "signup successfully"
})
}
这对我有用,只需尝试以下方法:
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
已弃用
根据Samyak Jain的答案,我使用Async Await
let isDelete = await MODEL_NAME.deleteMany({_id:'YOUR_ID', name:'YOUR_NAME'});
我真的很喜欢这种在异步/等待功能的 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)
}))
db.collection.remove(<query>,
{
justOne: <boolean>,
writeConcern: <document>
})