我有一个程序,它是一个事件创建者/定位器。我遇到的问题是从数据库中提取查询。在这个实例中,我只是尝试从数据库中提取特定的邮政编码,并显示从查询中提供的相应文档的详细信息。
private void findEvent() {
Log.d(TAG,"Start FindEvent Function");
eventRef.whereEqualTo("zip", searchZip.toString())
.limit(1).get()
.addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
@Override
public void onComplete(@NonNull Task<QuerySnapshot> task) {
if (task.isSuccessful()) {
Log.d(TAG, "Task Successful! Starting For Loop!");
for (QueryDocumentSnapshot document : task.getResult()) {
Log.d(TAG, document.getId()+"=>"+document.getData());
updateUI(document);
}
} else {
Log.w(TAG, "Error getting documents.", task.getException());
}
}
});
}//end findEvent function
当我运行程序时,在我的手机上点击启动上述功能的搜索按钮,我的活动没有输出任何内容。我检查日志,这就是我放入它的原因,在日志中,我得到了调试:“任务成功!开始循环!”然后什么都没有,当我期待我在updateUI函数中的调试日志,它告诉我函数正在启动。因此告诉我它没有运行updateUI函数。
您的查询可能只是没有返回任何结果,并且您的代码没有检查该情况。
在迭代传递给任务的QuerySnapshot之前:
QuerySnapshot qsnapshot = task.getResult();
您可以使用其isEmpty()方法来确定它是否实际包含任何文档:
if (qsnapshot.isEmpty()) {
Log.d(TAG, "Query resulted in no documents");
}