【发布时间】:2020-12-22 09:33:35
【问题描述】:
我正在为 GraphQL 使用 Amazon 的 Amplify 库。创建突变正在返回 响应中的非空数据,但更新突变返回空数据 回应。
Amplify.API.query(ModelQuery.list(Login.class), response -> {
boolean isThere = false;
for (Login login : response.getData()) {
if (login.getLoginEmail().equals(loginEmail)) {
isThere = true;
break;
}
}
if (isThere) {
Log.e("MyAmplifyApp", "Update Query");
Amplify.API.mutate(ModelMutation.update(todo),
response3 -> Log.i("MyAmplifyApp", "Updated Todo with id: " + response3.getData().getId()),
error -> Log.e("MyAmplifyApp", "Update failed", error)
);
} else {
Log.e("MyAmplifyApp", "Insert Query");
Amplify.API.mutate(ModelMutation.create(todo),
response2 -> Log.i("MyAmplifyApp", "Added Todo with id: " + response2.getData().getId()),
error -> Log.e("MyAmplifyApp", "Create failed", error)
);
}
}, error -> Log.e("MyAmplifyApp", "Query failure", error));
错误日志:
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String com.amplifyframework.datastore.generated.model.Login.getId()' on a null object reference
at com.example.todo.Activity.LoginActivity.lambda$null$0(LoginActivity.java:722)
at com.example.todo.Activity.-$$Lambda$LoginActivity$gU4azCKLr7DOG8SII3C8XdBDaxk.accept(lambda)
at com.amplifyframework.api.aws.AppSyncGraphQLOperation$OkHttpCallback.onResponse(AppSyncGraphQLOperation.java:140)
at okhttp3.internal.connection.RealCall$AsyncCall.run(RealCall.kt:519)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
at java.lang.Thread.run(Thread.java:760)
【问题讨论】:
-
response3.getData()failed then chained.getId()operation onnull也失败了 -
@xadm 我知道您的担忧,但在成功更新数据后它应该返回响应,否则它不会更新 DynamoDB 中的数据。
-
@Jameson 你对这个问题有什么想法吗??
-
不要假设任何事情...... console.log 整个响应,只是调试它,一步一步
-
@xadm 也使整个响应为空。如果我删除 console.log 语句它可以工作,但它不会将数据更新到 DynameDB。很抱歉,我没有假设我已经在我的表格中手动检查了。
标签: android graphql aws-amplify aws-appsync amplify