>Java >java지도 시간 >`count()` 메서드를 사용하여 Firestore 문서를 효율적으로 계산하는 방법은 무엇입니까?

`count()` 메서드를 사용하여 Firestore 문서를 효율적으로 계산하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-25 22:25:20331검색

How to Efficiently Count Firestore Documents Using the `count()` Method?

Firestore의 count() 메서드를 사용하여 컬렉션의 문서 개수를 계산하는 방법

Firestore에는 getDocumentCount()와 같은 명시적인 메서드가 없습니다. 컬렉션의 문서 수를 계산합니다. 그러나 계산 작업을 간소화하기 위해 count()라는 새로운 메서드가 도입되었습니다.

count() 메서드 사용

import com.google.cloud.firestore.Query;
import com.google.cloud.firestore.QueryDocumentSnapshot;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;

CompletableFuture<Long> future = new CompletableFuture<>();
Query query = db.collection("Posts");
query.get().addCallback(
    queryDocumentSnapshots -> {
      Long count = 0L;
      for (QueryDocumentSnapshot document : queryDocumentSnapshots.getDocuments()) {
        count++;
      }
      future.complete(count);
    },
    throwable -> future.complete(throwable)
);
// Retrieve the count asynchronously
try {
  Long count = future.get();
  System.out.println("Number of posts: " + count);
} catch (InterruptedException | ExecutionException e) {
  System.out.println("Error counting posts: " + e.getMessage());
}

세다() 방법

  • 확장 가능: count() 메서드는 집계를 수행하므로 수동으로 계산할 필요가 없으므로 특히 대규모 컬렉션에 유용합니다.
  • 효율성: 실제 문서가 아닌 색인 항목만 읽으므로 데이터가 줄어듭니다. 가져오는 중입니다.
  • 일관성: 반환된 개수는 쿼리 당시 컬렉션의 상태를 참조하므로 정확합니다.

대안 솔루션

  • Cloud Functions 사용 카운터: Cloud Functions를 사용하면 새 문서가 생성되거나 삭제될 때마다 별도의 문서에 저장된 카운터가 증가할 수 있습니다. 이 접근 방식은 고속 계산을 허용하지만 쓰기 시 최선의 노력 제한이 적용됩니다.
  • 클라이언트 측 카운터 유지 관리: 트랜잭션을 사용하여 로컬 카운터를 업데이트할 수 있습니다. 문서를 추가하거나 삭제하는 동안 클라이언트 측에서 정확성을 보장합니다. 그러나 추가 논리와 신중한 구현이 필요합니다.
  • 폴링: 정기적으로 컬렉션을 쿼리하고 결과를 계산하면 문서 수를 추정할 수 있지만 대기 시간이 발생하고 읽기 작업이 늘어날 수 있습니다. .

위 내용은 `count()` 메서드를 사용하여 Firestore 문서를 효율적으로 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.