很多nodejs的新手都是直接用mongodb本身直接操作数据库,我之前也是如此
不知道大家有没有遇到过这个错误: Error: db object already connecting, open cannot be called multiple times
也许你会说是异步写得不好,但是就算异步写得再好,也逃避不了这个错误 因为无论如何,都要用到db.open();这东西,而且访问完毕还得db.close();
于是就有一个问题:刷新得太快,或者多个用户同时访问数据库,数据库没来得及关闭,那个Error就会出现
可以做一下实验,在访问数据库的页面按住F5,就会很容易看到在页面上或者控制台上抛出的Error勒
用mongoose就不会出现这错误勒,因为一旦连接好数据库,db就会处于open状态,不存在访问时要打开,然后又要关闭的规则,然后我果断把所有mongodb部分改为mongoose,按住F5毫无压力啊,而且尼玛代码又短了一大截!
前后代码对比一下:
之前每次操作要open:
User.get = function get(username, callback) {
mongodb.open(function(err, db) {
if (err) {
return callback(err);
}
//读取 users 集合
db.collection('users', function(err, collection) {
if (err) {
mongodb.close();
return callback(err);
}
//查找 name 属性为 username 的文档
collection.findOne({name: username}, function(err, doc) {
mongodb.close();
if (doc) callback (err, doc);
else callback (err, null);
});
});
});
};
现在,建立好mongoose对象模型后只需几行代码即可实现相同的功能:
User.get = function get(username, callback) {
users.findOne({name:username}, function(err, doc){
if (err) {
return callback(err, null);
}
return callback(err, doc);
});
};
24 回复
@kimady 举一种最简单的做法:把 mongodb.open 写在最外围
mongodb.open(function(err, db) {
// 把所有其他代码都包含在这个里面,并且丢掉 mongodb,只使用 db
});
有用到schema的,只是没贴上去:
var userObj = new Schema({
name: {type: String, index: {unique: true}},
nick: String,
password: String,
email: String,
submit: Number,
solved: Number,
regTime: String,
privilege: String
});
mongoose.model('users', userObj);
var users = mongoose.model('users');