node.js mongooseを使用してドキュメントを削除するにはどうすればよいですか?
-
25-10-2019 - |
質問
FBFriendModel.find({
id: 333
}, function (err, docs) {
docs.remove(); //Remove all the documents that match!
});
上記は機能しないようです。レコードはまだそこにあります。
誰かが修正できますか?
解決 3
docs
ドキュメントの配列です。したがって、それは持っていません mongooseModel.remove()
方法。
アレイ内の各ドキュメントを個別に反復して削除できます。
または - (おそらく)一意のIDでドキュメントを見つけているように見えるので - 使用 findOne
それ以外の find
.
他のヒント
更新:Mongooseバージョン(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ドキュメント 詳細については。
私にとってこれは、バージョン3.8.1の時点で最高です:
MyModel.findOneAndRemove({field: 'newValue'}, function(err){...});
また、1つのdbコールのみが必要です。あなたが何も実行しないことを考えると、これを使用してください remove
検索と削除のアクション。
単にやる
FBFriendModel.remove().exec();
mongoose.model.find()
返品a クエリオブジェクト それもあります remove()
関数。
使用できます mongoose.model.findOne()
同様に、一意のドキュメントを1つだけ削除する場合。
それ以外の場合は、最初にドキュメントを取得してから削除する場所でも、従来のアプローチに従うことができます。
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);
}
});
一般化するには、使用できます。
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
});
FindOneに注意して、取り外してください!
User.findOne({name: 'Alice'}).remove().exec();
上記のコード すべてを削除します ではなく「アリス」という名前のユーザー 最初の1つ それだけ。
ちなみに、私はこのような文書を削除することを好みます:
User.remove({...}).exec();
またはコールバックを提供してexec()を省略します
User.remove({...}, callback);
model.remove({title:'danish'}, function(err){
if(err) throw err;
});
削除するオブジェクトが1つだけを探している場合は、使用できます
Person.findOne({_id: req.params.id}, function (error, person){
console.log("This object will get deleted " + person);
person.remove();
});
この例では、Mongooseはreq.params.idの一致に基づいて削除されます。
.remove()
のような作品 .find()
:
MyModel.remove({search: criteria}, function() {
// removed.
});
私はあなたが必要な場所で約束表記を好む
Model.findOneAndRemove({_id:id})
.then( doc => .... )
ドキュメントを削除するには、使用を好みます 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からの応答を待たずにドキュメントを削除する場合は、コールバックに合格しないでください。返されたクエリでexecに電話する必要があります
var removeQuery = FBFriendModel.remove({id : 333 });
removeQuery.exec();
削除関数内でクエリを直接使用することができます。
FBFriendModel.remove({ id: 333}, function(err){});
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 }`
})
});
削除()メソッドを使用できます。削除できます。
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
})
});
Samyak Jainの答えに従って、私はAsyncを待っています
let isDelete = await MODEL_NAME.deleteMany({_id:'YOUR_ID', name:'YOUR_NAME'});
db.collection.remove(<query>,
{
justOne: <boolean>,
writeConcern: <document>
})