【问题标题】:Removing documents from a mongodb collection from node.js从 node.js 的 mongodb 集合中删除文档
【发布时间】:2013-12-20 08:54:23
【问题描述】:

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

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

谢谢!

【问题讨论】:

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

标签: javascript node.js mongodb


【解决方案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();
        });
    });
});

【讨论】:

  • 它有效,但我想了解为什么您必须调用 close 以便实际发生删除...
猜你喜欢
  • 1970-01-01
  • 2017-02-21
  • 1970-01-01
  • 1970-01-01
  • 2016-12-27
  • 2018-07-20
  • 2013-08-23
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多