java - 如何批量更新 User 类(Parse.com,Android)中的所有对象?

标签 java android parse-platform parse-server

我最初犯了一个错误,忘记在用户注册时初始化我的数组字段(设计),所以在我的 Parse 仪表板中,行显示为 (undefined),我希望它们是[]。我必须为大约 5000 个用户执行此操作。我尝试了以下代码:

var query = new Parse.Query("User");
query.equalTo("designs", "(undefined)");
query.each(function(obj) {
  obj.set("designs", "[]");
  return obj.save();
}).then(function() {
  // All objects updated.
}, function(err) {
  console.log(err);
});

我认为 (undefined) 应该是别的东西,但我不确定是什么,因为它可能不是字符串。我该如何解决这个问题?

更新:第二次尝试。这是越来越近了吗?

    private void updateAllRows(final int skip) {

    ParseQuery<ParseUser> query = ParseUser.getQuery();
    query.setLimit(500);
    query.setSkip(skip);
    query.whereDoesNotExist("designs");
    query.findInBackground(new FindCallback<ParseUser>() {

        @Override
        public void done(List<ParseUser> results, ParseException e) {
            if (results.size() > 0) {

                // The query was successful.
                for (int i = 0; i < results.size(); i++) {
                    ParseUser user = results.get(i);
                    String[] designs = new String[0];
                    user.put("designs", Arrays.asList(designs));

                    try {
                        ParseUser.saveAll(results);
                        if (results.size() >= 500) {
                            updateAllRows(skip + 500); // make a recursion call with different skip value
                        }
                    } catch (ParseException e1) {
                        e1.printStackTrace();
                    }
                }

                Log.d(getClass().toString(), ": The batch job was successfully completed.");

            } else {
                // The query was unsuccessful.
                Log.d(getClass().toString(), ": The batch job was not successful.");
            }
        }
    });
}

我使用类的 onCreate 方法中的以下内容调用上述函数:

int skip = 0;
updateAllRows(skip);

这是不使用云代码的最佳方式吗?

错误:

08-08 12:38:43.034 24003-24053/? E/HttpOperation: [luq{checkandengageuser, getmobileexperiments}] Unexpected exception
                                                  java.io.IOException: 1 of 2 operations in the batch failed
                                                      at luj.a(PG:268)
                                                      at lth.o(PG:10642)
                                                      at ltc.a(PG:1402)
                                                      at lth.i(PG:154)
                                                      at ly.f(PG:51849)
                                                      at dsr.a(PG:1255)
                                                      at dsr.a(PG:20077)
                                                      at dsr.a(PG:706)
                                                      at dss.run(PG:1548)
                                                      at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:423)
                                                      at java.util.concurrent.FutureTask.run(FutureTask.java:237)
                                                      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
                                                      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
                                                      at java.lang.Thread.run(Thread.java:818)

最佳答案

JavaScript 版本 1. 您可以使用 Parse.Object.saveAll 在一次服务调用中保存多个对象 2. 您必须使用limitskip 才能一次对500 个(或更少)项目执行此操作。 3. 您需要使用query.doesNotExist("designs"); 以获取设计列中包含未定义的所有项目

function updateAllRows(skip) {

  var query = new Parse.Query(Parse.User);
  query.limit(500);
  query.skip(skip);
  // get recors where designs is not exist or is undefined      
  query.doesNotExist("designs");

  query.find().then(function(results) {

    // if we got results then change the designs property 
    if (results.length > 0) {

      for (var i = 0; i < results.length; i++) {
        var item = results[i];
        item.set("designs", []);
      }

      Parse.Object.saveAll(results).then(function() {
        // if we got 500 or more results then we know
        // that we have more results
        // otherwise we finish
        if (results.length >= 500) {
          updateAllRows(skip + 500); // make a recursion call with different skip value
        }

      }, function(err) {
        // error occured 
      });
    }
  }, function(error) {
    // error occured while trying to fetch data 
  });
};

安卓Java版

private void updateAllRows(final int skip){

    ParseQuery<ParseUser> query = ParseUser.getQuery();
    query.setLimit(500);
    query.setSkip(skip);
    query.whereDoesNotExist("designs");

    query.findInBackground(new FindCallback<ParseUser>() {
        @Override
        public void done(final List<ParseUser> users, ParseException e) {

            if (e == null){
                for (ParseUser user : users){
                    user.put("designs",new ArrayList<>());
                }

                // save all objects in one server call
                ParseObject.saveAllInBackground(users, new SaveCallback() {
                    @Override
                    public void done(ParseException e) {

                        if (e == null){
                            if (users.size() >= 500){
                                updateAllRows(skip + 500);
                            }
                        } else {
                            // error  while saving objects
                        }


                    }
                });
            }
        }
    });
}

顺便说一句!您还可以在云代码中创建云函数并从客户端触发此函数

关于java - 如何批量更新 User 类(Parse.com,Android)中的所有对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38825021/

相关文章:

Android - Firebase 查询 startAt 未按预期工作

android - 按键事件在 Android 设备上不起作用

javascript - 如何保存引用 User 对象的 Parse 对象?

javascript - Parse Javascript SDK 范围内的位置

java - JTable 在悬停/单击/滚动新数据时显示以前的数据

Java——当用户输入日期字符串时显示一年中的某一天

java - 如何在 Spring Boot 的每个请求中获取当前用户?

android - 一个基本的文本到语音应用程序不工作

ios - 如果删除 PFUser,则以编程方式删除与 PFUser.objectID 关联的数据

java - 调整窗口大小时 Canvas 会被清除