I’m using the Node.JS driver for MongoDB, and I’d like to perform a synchronous query, like such:
function getAThing()
{
var db = new mongo.Db("mydatabase", server, {});
db.open(function(err, db)
{
db.authenticate("myuser", "mypassword", function(err, success)
{
if (success)
{
db.collection("Things", function(err, collection)
{
collection.findOne({ name : "bob"}, function(err, thing)
{
return thing;
});
});
}
});
});
}
The problem is, db.open is an asychronous call (it doesn’t block), so the getAThing returns “undefined” and I want it to return the results of the query. I’m sure I could some sort of blocking mechanism, but I’d like to know the right way to do something like this.
There’s no way to make this synchronous w/o some sort of terrible hack. The right way is to have
getAThingaccept a callback function as a parameter and then call that function oncethingis available.Node 7.6+ Update
async/awaitnow provides a way of coding in a synchronous style when using asynchronous APIs that return promises (like the native MongoDB driver does).Using this approach, the above method can be written as:
Which you can then call from another
asyncfunction aslet thing = await getAThing();.However, it’s worth noting that
MongoClientprovides a connection pool, so you shouldn’t be opening and closing it within this method. Instead, callMongoClient.connectduring your app startup and then simplify your method to:Note that we don’t call
awaitwithin the method, instead directly returning the promise that’s returned byfindOne.