Firebase 查询查找包含参与者的聊天
背景:
下的数据结构考虑代表一个聊天系统,其中聊天有参与者和聊天项目。目标是查询“聊天”表,以根据给定的用户名字符串检索具有特定参与者的所有聊天。
初始尝试:
提供的代码尝试使用 orderByChild 和 equalTo 方法通过“participants”子项查询“chats”表,指定用户名以查找匹配项。但是,这种方法有局限性,因为:
倒排索引方法:
要解决这些限制,建议通过创建映射的“userChatrooms”节点来反转数据结构用户进入他们参与的聊天室。这样可以进行有效的过滤user:
userChatrooms: { john: { chatRoom1: true, chatRoom2: true }, puf: { chatRoom1: true, chatRoom3: true } }
使用倒排索引查询:
使用倒排索引结构,查找用户的所有聊天变得简单:
ref.child("userChatrooms").child("john")
Cloud Firestore 替代方案:
云Firestore 通过其数组包含运算符为此类查询提供了更好的支持。这允许直接过滤数组中包含特定值的文档:
Query query = firestore.collection("chats") .whereArrayContains("participants", username);
以上是如何高效查询 Firebase 或 Firestore 中包含特定参与者的聊天?的详细内容。更多信息请关注PHP中文网其他相关文章!