首頁 >web前端 >js教程 >如何根據參與者的狀態有效率地查詢 Firebase 聊天?

如何根據參與者的狀態有效率地查詢 Firebase 聊天?

Barbara Streisand
Barbara Streisand原創
2024-12-31 14:04:14868瀏覽

How to Efficiently Query Firebase Chats Based on Participant Presence?

如何依照參與者的狀態查詢聊天

問題陳述:

問題陳述:

給定Fire表示與多個參與者的聊天對話的資料庫結構,我們如何有效地查詢包含特定參與者的聊天?

return this.af.database.list('chats', {
    query: {
        orderByChild: 'participants',
        equalTo: username, // How to check if participants contain username
    }
});

目前查詢(無效):

  • 目前查詢有問題:
資料結構使用數組來表示參與者,允許重複

Firebase只允許在物件內的固定路徑上建立索引,這使得過濾參與者/使用者名稱等嵌套值變得困難。

推薦解決方案:反轉索引
  • 為了優化查詢,建議倒置索引結構,透過資料扁平化與聊天室上拉與使用者層級的關係。這涉及到:
在 userChatrooms/{username} 下儲存每個使用者的一組聊天室 ID。

在集合中使用 true 值表示該使用者是聊天室的參與者。

userChatrooms: {
  john: {
    chatRoom1: true,
    chatRoom2: true
  },
  puf: {
    chatRoom1: true,
    chatRoom3: true
  }
}

修訂數據結構:

ref.child('userChatrooms').child(username)

更新的查詢:

  • 倒排索引的好處:
  • 允許使用特定使用者高效檢索聊天室清單單一查詢。
支援根據參與者的狀態查詢聊天室,無需動態索引。 透過對使用者的視角進行建模,更直接反映應用程式的功能。

以上是如何根據參與者的狀態有效率地查詢 Firebase 聊天?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn