从node.js中删除mongodb集合中的文档

时间:2013-12-20 08:54:23

标签: javascript node.js mongodb

我是mongoDB的新手,对Node.js没有经验,所以请原谅下面的代码是否远非完美。

目标是从集合中删除文档,由_id引用。删除完成(在mongo shell中检查),但代码没有结束(运行node myscript.js不会让我的shell回来)。如果我添加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 个答案:

答案 0 :(得分:19)

欢迎来到异步风格:

  • 你不应该使用throw for callback,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();
        });
    });
});