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

17

我对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();
});

我不需要关闭连接吗?如果我没有关闭连接而程序没有结束会发生什么?

谢谢!


2
什么也不会发生,你的程序只是在等待来自Mongo驱动程序的一些I/O。当然,你知道什么也不会到达,你也不会发送任何东西,但Node不知道这一点,因此它无法完成。 - kamituel
1个回答

22

欢迎来到异步风格:

  • 回调函数中不应使用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();
        });
    });
});

它能够工作,但我想知道为什么必须调用close才能实际发生删除... - Jeep87c

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接