Удаление документов из коллекции 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();
        });
    });
});
Другие вопросы по тегам