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

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

Susan Sarandon
发布: 2024-12-19 16:17:13
原创
135 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板