我试图根据文档时间戳删除firestore中的项目,我相当确定代码是正确的,我确定时间戳匹配,但我得到一个空指针
java.lang.NullPointerException: Attempt to invoke virtual method
'com.google.android.gms.tasks.Task
com.google.firebase.firestore.DocumentReference.delete()' on a null object
reference
所以我到目前为止...当活动开始时我运行一个查询并从firestore获取所有消息文档,然后将它们放入对象并在带有自定义的回收器视图中显示它们适配器(基本的东西)。我现在正在做的是创建一个删除方法,所以我在我的适配器中创建了一个方法,将所选项添加到我可以开始删除的列表中(getSelectedItems)并且我使用了下面的firestore查询删除项目
ArrayList<UserMessage> messages = new ArrayList<>();
messages.addAll(mMessageAdapter.getSelectedItems());
final CollectionReference userRef =
db.collection("users")
.document(userId)
.collection("contacts")
.document(myUser.get_id())
.collection("messages");
for (UserMessage message : messages) {
System.out.println(message.getTime_stamp());
//this prints like this- Sat Jun 02 12:20:56 GMT+01:00 2018
Query query = userRef.whereEqualTo("time_stamp",
message.getTime_stamp());
query.get().addOnCompleteListener(new
OnCompleteListener<QuerySnapshot>() {
@Override
public void onComplete(@NonNull Task<QuerySnapshot> task) {
if (task.isSuccessful()) {
System.out.println("found an item to delete");
for (DocumentSnapshot doc : task.getResult()) {
doc.getDocumentReference(doc.getId())
.delete()
.addOnSuccessListener(new
OnSuccessListener<Void>() {
@Override
public void onSuccess(Void aVoid) {
System.out.println("deleted an item");
messagesDeleted[0]++;
prog3Message = ("Deleted " +
messagesDeleted[0] + " of " +
allMessages[0] + " messages");
runOnUiThread(changeMessage);
}
});
}
if (messagesDeleted[0] == allMessages[0]) {
prog3.dismiss();
showMenuItems = false;
///selectedMessageList.clear();
hideShowMenu(showMenuItems);
mMessageAdapter.clearSelections();
//System.out.println("all complete ");
}
} else {
}
}
});
}
因此,为了开始排除故障,我在每个文档的第一个查询中添加了一个print语句(获取所有消息)我从文档和对象中打印时间戳(以防万一)并打印出来像这样
I/System.out: object data Sat Jun 02 12:20:56 GMT+01:00 2018
I/System.out: document data Sat Jun 02 12:20:56 GMT+01:00 2018
I/System.out: object data Sat Jun 02 12:23:16 GMT+01:00 2018
I/System.out: document data Sat Jun 02 12:23:16 GMT+01:00 2018
你可以看到匹配上面的删除方法的打印 - 星期六02 02:20:56 GMT + 01:00 2018 - 然而我在运行查询时得到一个空指针,一个有趣的事实是当你去火店时间戳显示像2018年6月1日下午5:55:49 UTC + 1这是一个不同的格式和不同的区域所以我尝试了一点点,最后这样做(不是很优雅)
SimpleDateFormat dateFormat =
new SimpleDateFormat("MMMM dd, yyyy HH:mm:ss aa", Locale.US);
dateFormat.setTimeZone(TimeZone.getTimeZone("UTC"));
String formatted = dateFormat.format(message.getTime_stamp());
String[] parts = formatted.split(" ");
StringBuilder stringBuilder = new StringBuilder();
for (int i = 0; i < parts.length; i++){
if(i == 2){
stringBuilder.append(parts[i] + " at ");
}else if (i == parts.length -1){
stringBuilder.append(parts[i].toUpperCase() + " UTC+1");
}else{
stringBuilder.append(parts[i] + " ");
}
}
System.out.println(stringBuilder.toString());
//June 02, 2018 at 11:20:56 AM UTC+1
这给了我正确的模式,但是时间现在是一个小时,任何人都可以告诉我,如果我试图重新发明轮子,希望这是一个更好的方式
答案 0 :(得分:1)
我无法弄清楚这一点并决定改为向firestore写一条消息然后用其id更新项目,以便它读取集合(用户)文档{userId}集合(联系人)文档{contactId}集合(消息)文档{ messageId}文档值id = messageId values message =&#34; blah blah&#34;这样我就可以通过id
删除每个项目