I am having trouble understanding node.js.
Example, MongoDB access, here’s what I’ve got (mydb.js):
var mongodb = require('mongodb'),
server = new mongodb.Server('staff.mongohq.com', 10030, {
auto_reconnect: true
}),
db = new mongodb.Db('mydb', server);
function authenticateAndGo(db, handle) {
db.authenticate('username', 'password', function(err) {
if (err) {
console.log(err);
return;
}
console.log('Database user authenticated');
var collection = new mongodb.Collection(db, 'test');
handle(collection);
});
}
function query(handle) {
db.open(function(err, db) {
if( err ) {
console.log(err);
return;
}
console.log('Database connected');
authenticateAndGo(db, handle);
});
};
exports.query = query;
So, if I want to use it later, I would
var mydb = require('./mydb');
mydb.query(function(collection) {
collection.find({}, {
limit: 10
}).toArray(function(err, docs) {
console.log(docs);
});
});
But, If I do multiple calls, like so:
var mydb = require('./mydb');
mydb.query(function(collection) {
collection.find({}, {
limit: 10
}).toArray(function(err, docs) {
console.log(docs);
});
});
mydb.query(function(collection) {
collection.find({}, {
limit: 10
}).toArray(function(err, docs) {
console.log(docs);
});
});
I get an exception:
Error: db object already connecting, open cannot be called multiple times
I think that there is really something fundamental that I do not understand about all this and it is probable that this question is stupid …
Anyway, all help is welcome.
Thanks in advance.
mydb.js:use.js:Result:
on success:
on failure:
[Original Answer]:
You’re opening the
dbmultiple times (once in eachquery). You should open the database just once, and use thedbobject in the callback for later use.You’re using the same variable name multiple times, and that might’ve caused some confusion.
I’ve changed the above code a little (
db1for the original db,db2for the opened db). As you can see, you’re openingdb1multiple times, which is not good. extract the code for opening into another method and use it ONCE and use thedb2instance for all your queries/updates/removes/…