I am new to node.js, and heroku, I built a small app that uses node.js and retrieves some data from a mongodb instance. I setup the whole thing but my problem is I think a simple syntactical issue with mongodb.
I need to know on starting the app that my collection has any stuff in it or not, if not, than initialize it. I tried calling collection.count() but returns undefined.
I tried doing this
mongo.connect(mongoUri, {}, function(err, database) {
  if(!err) {
      db = database;
      console.log("Connected to 'testdb' database, HERE");
      db.collection('tests', {safe:true}, function(err, collection) {
          if (err) {
              console.log("The 'tests' collection doesn't exist. Creating it ");
              populateDB();//This would work for the first time I install the app on heroku
          }
          else { //Collection exists, but nothing is in it, this is where I am lost
             console.log("now I am HERE");
             //I do not know how to mimic this piece of code
             //if((collection("tests").find().toArray.size() == 0 or empty or the equivalent of it) {
             //    populateDB();
             //}
             console.log((collection("tests").find().toArray.size()));
          }
      });
  }
  else {
      console.log("COULD NOT CONNECT TO MONGO: " + mongoUri);
  }
});
any help is appreciated.
Any MongoDB driver methods that access the data in the database (like count and toArray), provide their results to the caller asynchronously via a callback function parameter rather than via a return value so that they don't block the single node.js thread.
So the check would go something like this:
collection.count(function (err, count) {
    if (!err && count === 0) {
        populateDB();
    }
});
                        Great question and great answer, BUT! In case you have a lot of collections and a lot of documents inside each collection, this can take forever! We only need to know if a collection has at least one item then we can skip this collection, it's not empty... Use {limit: 1} in the options param
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With