2013-11-25 3 views
6

Я написал асинхронное задание фонового облака для Parse Framework, которое генерирует имя пользователя для каждого пользователя, основанное на их электронной почте, перед символом «@». К сожалению, я получаю сообщение об ошибке «слишком много операций подсчета» при выполнении задания. Есть ли способ, чтобы запросы и сохранения выполнялись последовательно, а не параллельно? Я видел в документации это возможно с обещаниями, но я в замешательстве, как заставить его работать с вложенными запросами.Запуск синхронных запросов в Parse Framework Cloud Code

Parse.Cloud.job("generateUsernameForEveryUser", function(request, status) { 

    // Set up to modify user data 
    Parse.Cloud.useMasterKey(); 
    var counter = 0; 
    // Query for all users 
    var query = new Parse.Query(Parse.User); 
    query.each(function(user) { 

    createUsernameForUser(user, 0, { 
     success: function(username) { 
     if(username == null) { 
      status.error(); 
     } else { 
      user.set("displayUsername", username); 
      user.set("displayUsernameUppercase", username.toUpperCase()); 
      user.save(); 
     } 
     }, 
     error: function(error) { 
     status.error("Error: " + error.message); 
     }   

    }); 

    }).then(function() { 
    // Set the job's success status 
    status.success("Username generation completed successfully."); 
    }, function(error) { 
    // Set the job's error status 
    status.error("Uh oh, something went wrong."); 
    }); 

}); 

function createUsernameForUser(user, count, callback) { 

    var generatedUsername = user.getEmail().substring(0, user.getEmail().indexOf("@")); 

    if(count > 0) { 
    //Quotes added to ensure no math is done between generatedUsername and count 
    generatedUsername = "" + generatedUsername + "" + count; 
    } 

    var userQuery = new Parse.Query(Parse.User); 
    userQuery.equalTo("displayUsernameUppercase", generatedUsername.toUpperCase()); 
    userQuery.count({ 

    success: function(userCount) { 

     if(userCount > 0) { 
     createUsernameForUser(user, count + 1, { 
      success : function(responseUsername) { 
      callback.success(responseUsername); 
      }, 
      error: function(error) { 
      callback.error(error.message); 
      } 
     }); 
     } 

     else { 
     callback.success(generatedUsername); 
     } 

    }, 
    error: function(error) { 
     console.log("Error trying to count users: " + error.message); 
     callback.error("Error trying to count users: " + error.message); 
    } 

    });//End of userQuery call 

} 

ответ

0

Это очень поздний ответ, но это будет полезно для людей, проходящих через это.

too many count operations ошибка возвращается, потому что query.each будет работать, только если у нас есть данные из 100 или менее строк для этого класса.

Мы можем получения идеальной такое же требование следующим образом:

  1. Получить все пользователи.
  2. Создайте имена пользователей и сохраните их в массиве. Подробнее см. Парсерные операции parse.com. var users = new Array(); .... push all the created user objects to users .... Parse.Object.saveAll(users); //save the list -

Надеюсь, это решает.