如何使用 Mongoose 从集合中删除所有文档?

我知道怎么..。

  • 删除单个文档。
  • 删除集合本身。
  • 使用 Mongo 从集合中删除所有文档。

但是我不知道如何从猫鼬的收藏品中删除所有的文件。我希望在用户单击按钮时执行此操作。我假设我需要向某个端点发送一个 AJAX 请求,然后让端点执行删除操作,但是我不知道如何在端点处理删除操作。

在我的示例中,我有一个 Datetime集合,我希望在用户单击按钮时删除所有文档。

api/datetime/index.js

'use strict';


var express = require('express');
var controller = require('./datetime.controller');


var router = express.Router();


router.get('/', controller.index);
router.get('/:id', controller.show);
router.post('/', controller.create);
router.put('/:id', controller.update);
router.patch('/:id', controller.update);
router.delete('/:id', controller.destroy);


module.exports = router;

Api/datetime/datetime.controller. js

'use strict';


var _ = require('lodash');
var Datetime = require('./datetime.model');


// Get list of datetimes
exports.index = function(req, res) {
Datetime.find(function (err, datetimes) {
if(err) { return handleError(res, err); }
return res.json(200, datetimes);
});
};


// Get a single datetime
exports.show = function(req, res) {
Datetime.findById(req.params.id, function (err, datetime) {
if(err) { return handleError(res, err); }
if(!datetime) { return res.send(404); }
return res.json(datetime);
});
};


// Creates a new datetime in the DB.
exports.create = function(req, res) {
Datetime.create(req.body, function(err, datetime) {
if(err) { return handleError(res, err); }
return res.json(201, datetime);
});
};


// Updates an existing datetime in the DB.
exports.update = function(req, res) {
if(req.body._id) { delete req.body._id; }
Datetime.findById(req.params.id, function (err, datetime) {
if (err) { return handleError(res, err); }
if(!datetime) { return res.send(404); }
var updated = _.merge(datetime, req.body);
updated.save(function (err) {
if (err) { return handleError(res, err); }
return res.json(200, datetime);
});
});
};


// Deletes a datetime from the DB.
exports.destroy = function(req, res) {
Datetime.findById(req.params.id, function (err, datetime) {
if(err) { return handleError(res, err); }
if(!datetime) { return res.send(404); }
datetime.remove(function(err) {
if(err) { return handleError(res, err); }
return res.send(204);
});
});
};


function handleError(res, err) {
return res.send(500, err);
}
161540 次浏览

在 MongoDB 中,db.Collection.move ()方法从集合中删除文档。您可以从集合中删除所有文档,删除符合条件的所有文档,或者将操作限制为只删除一个文档。

资料来源: 蒙哥布

如果你正在使用芒果皮,只要做:

db.Datetime.remove({})

就你而言,你需要:

你没有给我看删除按钮,所以这个按钮只是一个例子:

<a class="button__delete"></a>

将控制器更改为:

exports.destroy = function(req, res, next) {
Datetime.remove({}, function(err) {
if (err) {
console.log(err)
} else {
res.end('success');
}
}
);
};

在客户端 js 文件中插入 ajax delete 方法:

        $(document).ready(function(){
$('.button__delete').click(function() {
var dataId = $(this).attr('data-id');


if (confirm("are u sure?")) {
$.ajax({
type: 'DELETE',
url: '/',
success: function(response) {
if (response == 'error') {
console.log('Err!');
}
else {
alert('Success');
location.reload();
}
}
});
} else {
alert('Canceled!');
}
});
});

空对象将匹配所有这些对象。

不推荐使用 .remove()。相反,我们可以使用 delete temany

DateTime.deleteMany({}, callback).

MongoDB shell 版本4.2.6
节点 v14.2.0

假设您有一个 Tour Model: tourModel.js

const mongoose = require('mongoose');


const tourSchema = new mongoose.Schema({
name: {
type: String,
required: [true, 'A tour must have a name'],
unique: true,
trim: true,
},
createdAt: {
type: Date,
default: Date.now(),
},
});
const Tour = mongoose.model('Tour', tourSchema);


module.exports = Tour;

现在,您希望从 MongoDB 中一次性删除所有的参观,我还提供了连接远程集群的连接代码。 我使用了 delete temany () ,如果您没有传递任何参数到 delete temany () ,那么它将删除 Tour 集合中的所有文档。

const mongoose = require('mongoose');
const Tour = require('./../../models/tourModel');
const conStr = 'mongodb+srv://lord:<PASSWORD>@cluster0-eeev8.mongodb.net/tour-guide?retryWrites=true&w=majority';
const DB = conStr.replace('<PASSWORD>','ADUSsaZEKESKZX');
mongoose.connect(DB, {
useNewUrlParser: true,
useCreateIndex: true,
useFindAndModify: false,
useUnifiedTopology: true,
})
.then((con) => {
console.log(`DB connection successful ${con.path}`);
});


const deleteAllData = async () => {
try {
await Tour.deleteMany();
console.log('All Data successfully deleted');
} catch (err) {
console.log(err);
}
};