【发布时间】: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