Удаление документов из коллекции mongodb из node.js
Я совершенно новичок в mongoDB и не имел опыта работы с Node.js, поэтому извините, если приведенный ниже код далек от совершенства.
Цель состоит в том, чтобы удалить документ из коллекции, на которую ссылается его _id
, Удаление выполнено (проверено в оболочке mongo), но код не заканчивается (выполняется node myscript.js
не возвращает мою оболочку). Если я добавлю db.close()
я получил { [MongoError: Connection Closed By Application] name: 'MongoError' }
,
var MongoClient = require("mongodb").MongoClient;
var ObjectID = require("mongodb").ObjectID;
MongoClient.connect('mongodb://localhost/mochatests', function(err, db) {
if (err) {
console.log("error connecting");
throw err;
}
db.collection('contacts', {}, function(err, contacts) {
if (err) {
console.log("error getting collection");
throw err;
}
contacts.remove({_id: ObjectID("52b2f757b8116e1df2eb46ac")}, {safe: true}, function(err, result) {
if (err) {
console.log(err);
throw err;
}
console.log(result);
});
});
db.close();
});
Разве я не должен закрывать соединение? Что происходит, когда я не закрываю это, и программа не заканчивается?
Спасибо!
1 ответ
Решение
Добро пожаловать в асинхронный стиль:
- Вы не должны использовать throw для обратного вызова, throw подходит для стека функций
db.close()
должен быть в обратном вызове, после удаления сделано.
Пример:
MongoClient.connect('mongodb://localhost/mochatests', function(err, db) {
db.collection('contacts', {}, function(err, contacts) {
contacts.remove({_id: ObjectID("52b2f757b8116e1df2eb46ac")}, function(err, result) {
if (err) {
console.log(err);
}
console.log(result);
db.close();
});
});
});