首页 >web前端 >js教程 >如何高效查询 Firebase 或 Firestore 中包含特定参与者的聊天?

如何高效查询 Firebase 或 Firestore 中包含特定参与者的聊天?

Susan Sarandon
Susan Sarandon原创
2024-12-19 16:17:13138浏览

How to Efficiently Query Firebase or Firestore for Chats Containing a Specific Participant?

Firebase 查询查找包含参与者的聊天

背景:

下的数据结构考虑代表一个聊天系统,其中聊天有参与者和聊天项目。目标是查询“聊天”表,以根据给定的用户名字符串检索具有特定参与者的所有聊天。

初始尝试:

提供的代码尝试使用 orderByChild 和 equalTo 方法通过“participants”子项查询“chats”表,指定用户名以查找匹配项。但是,这种方法有局限性,因为:

  • 参与者存储为数组:此数据结构不能准确反映聊天中的参与者应该是唯一的这一事实。
  • 索引限制:Firebase 需要预定义索引来查询嵌套路径,这在处理时可能会变得很麻烦动态数据。

倒排索引方法:

要解决这些限制,建议通过创建映射的“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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn