MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Pętla z asynchronicznymi wywołaniami zwrotnymi w mongoose/mongodb/node

Myślę, że chciałbyś użyć czegoś takiego jak async koordynowanie tych próśb; map() wydaje się być dobrym wyborem:

Author.find({}, function (err, authors) {
  async.map(authors, function(author, done) {
    Book.count({author: author._id}, function(err, count) {
      if (err)
        done(err);
      else
      {
        done(null, {
          id    : author._id,
          name  : author.name,
          count : count
        });
      }           
    });
  }, function(err, author_array) {
    if (err)
    {
      // handle error
    }
    else
    { 
      /*
      res.writeHead(200, { 'Content-Type': 'application/json' });
      res.write(JSON.stringify({ authors: author_array }));
      res.end();
      */
      // Shorter:
      res.json(author_array);
    }
  });
});



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. porównaj dwa pola tego samego dokumentu

  2. Wstaw słownik do MongoDB za pomocą sterownika c#

  3. przechowywanie pełnego tekstu z pliku txt do mongodb

  4. Importowanie kolekcji mongo do istniejącej kolekcji bez jej zastępowania

  5. Jak używać mongoimport do importowania csv