sql >> Database >  >> NoSQL >> MongoDB

Items opslaan in Mongoose For Loop met schemamethoden

Als u dezelfde asynchrone taak moet uitvoeren voor items in een array, gebruik dan geen gewone for-lus. Bekijk async.each , het past beter in uw scenario, zoals (alleen de else deel van je code):

var body = JSON.parse(response.body);

async.each(body.data, function (photoData, callback) {

  // ------------------------------------------------
  // If there is no caption, skip it
  //

  if (!photoData.caption){
    text = '';
  }
  else{
    text = photoData.caption;
  }

  // ------------------------------------------------
  // Create new photo object
  //

  var photo = new Photo({
    link: photoData.link,
    username: photoData.user.username,
    profilePicture: photoData.user.profile_picture,
    imageThumbnail: photoData.images.thumbnail.url,
    imageFullsize: photoData.images.standard_resolution.url,
    caption: text,
    userId: photoData.user.id,
    date: photoData.created_time,
    _id: photoData.id
  });

  photo.checkBlacklist(function(err, blacklist){

    if (!blacklist){
      photo.save(function(err, item){
        if (err){
          console.log(err);
        }

        console.log('Saved', item);
        callback();
      });
    }

  });

}, function (error) {
  if (error) res.json(500, {error: error});

  console.log('Photos saved');
  return res.json(201, {msg: 'Photos updated'} );
});

Vergeet niet te installeren

npm install async

en vereisen async :

var async = require('async');


  1. Mongoose findbyid() retourneert null

  2. MongoDB $oid versus ObjectId

  3. Explain() in Mongodb:verschillen tussen nscanned en nscannedObjects

  4. Het resultaat van een MongoDB-query opslaan