Android Firestore嵌套HashMap上的多个whereEqualTo

Android Firestore嵌套HashMap上的多个whereEqualTo,android,firebase,google-cloud-firestore,Android,Firebase,Google Cloud Firestore,考虑到多个whererraycontains()不起作用,我对嵌套HashMap上的多个whereEqualTo()有问题 我正在用firebase制作一个简单的聊天应用程序,在某种程度上,我需要确定firestore的聊天文档是否存在两个用户ID。我当前的firestore聊天设置是: chatId : { lastMessageText: string lastMessageTime: long memberIds: { userId1 : true

考虑到多个whererraycontains()不起作用,我对嵌套HashMap上的多个whereEqualTo()有问题

我正在用firebase制作一个简单的聊天应用程序,在某种程度上,我需要确定firestore的聊天文档是否存在两个用户ID。我当前的firestore聊天设置是:

chatId : {
    lastMessageText: string
    lastMessageTime: long
    memberIds: {
        userId1 : true
        userId2 : true
    }
}
我的代码是:

    chatsCollection
        .whereEqualTo("memberIds., + currentUser.getUsername() "true") // which is memberIds.userId1
        .whereEqualTo("memberIds." + opponentUser.getUsername(), "true")
        .get()
        .addOnCompleteListener(task -> {
            if (task.isSuccessful()) {
                if (!task.getResult().isEmpty()) {
                    // some logic
                }
            } else {
                Log.d(TAG, "Error getting documents: ", task.getException());
            }
        });
但总是返回空结果。我查了一下商店,所有的东西都在那里。我错过了什么


提前感谢。

您的代码看起来可能试图将数据库中的布尔值与字符串进行比较。如果数据库中有布尔类型字段,那么在查询中也应该使用布尔类型值(而不是带引号的字符串)。始终确保类型匹配。

您的代码看起来可能试图将数据库中的布尔值与字符串进行比较。如果数据库中有布尔类型字段,那么在查询中也应该使用布尔类型值(而不是带引号的字符串)。始终确保类型匹配。

真是我的耻辱。对的非常感谢。我真丢脸。对的非常感谢。