簡介
在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中文網其他相關文章!