首页 >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