我是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(); });
我不必关闭连接吗?当我没有关闭它并且程序没有结束时发生了什么?
谢谢!
欢迎来到异步风格:
你不应该使用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(); }); }); });