首頁 >Java >java教程 >如何有效率地統計 Firestore 集合中的文件數量?

如何有效率地統計 Firestore 集合中的文件數量?

Patricia Arquette
Patricia Arquette原創
2024-11-19 18:03:03445瀏覽

How to Efficiently Count Documents in a Firestore Collection?

取得Firestore 集合中的文件計數

簡介

在Firebase Firestore 中,沒有直接方法取得的文件計數。然而,隨著 Firestore 最近的更新和新功能的引入,有多種方法可以實現這一目標。

新的count() 方法

截至10 月20 日2022 年,Firestore 提供了新的count() 方法,使您能夠在不讀取文檔實際內容的情況下對文件進行計數。它會傳回一個查詢,該查詢會對與查詢相符的文件進行計數。對於諸如 count() 之類的聚合查詢,您將按查詢匹配的每批最多 1000 個索引條目的一個文件讀取費用。

分散式計數器

On 2021 年 7 月 10 日,Firebase 引進了分散式計數器擴充。它提供了高度可擴展的計數器服務,專為追蹤高速操作(例如視圖、點讚或共享)的應用程式而客製化。使用此擴展,您可以克服每秒一次寫入操作的最大限制。

文件計數的程式碼範例

1.使用 count()方法

Query countQuery = db.collection("Posts")
                     .whereEqualTo("status", "published");

Task<QuerySnapshot> task = countQuery.get();
task.addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
    @Override
    public void onComplete(@NonNull Task<QuerySnapshot> task) {
        if (task.isSuccessful()) {
            int count = task.getResult().size();
            Log.d("TAG", count + "");
        } else {
            Log.d(TAG, "Error getting documents: ", task.getException());
        }
    }
});

2.使用舊方法

db.collection("Posts")
   .get()
   .addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
       @Override
       public void onComplete(@NonNull Task<QuerySnapshot> task) {
           if (task.isSuccessful()) {
               int count = 0;
               for (DocumentSnapshot document : task.getResult()) {
                   count++;
               }
               Log.d("TAG", count + "");
           } else {
               Log.d(TAG, "Error getting documents: ", task.getException());
           }
       }
   });

其他注意事項

舊方法的限制:

使用舊方法對於小型資料集效果很好,但由於每個文件的讀取操作,對於大型資料集可能效率低下。

分散式計數器的準確性:

請注意,雲函數是寫入時盡力而為,這意味著更新計數器可能會略有延遲,並且可能不會立即準確,特別是在資料集很大或寫入負載很高的情況下。

結論

新的 count() 方法提供了一種方便且高效能的方法來對 Firestore 集合中的文件進行計數。如果您需要具有即時更新和可擴展性的計數器,請考慮使用分散式計數器擴充。

以上是如何有效率地統計 Firestore 集合中的文件數量?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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