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

mar*_*c0s 16 javascript mongodb node.js

我是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();
});
Run Code Online (Sandbox Code Playgroud)

我不必关闭连接吗?当我没有关闭它并且程序没有结束时发生了什么?

谢谢!

dam*_*hat 20

欢迎来到异步风格:

  • 你不应该使用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();
        });
    });
});
Run Code Online (Sandbox Code Playgroud)