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
欢迎来到异步风格:
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)
归档时间: |
|
查看次数: |
27430 次 |
最近记录: |