ホームページ  >  記事  >  Java  >  Firestore コレクションとサブコレクションを効果的に削除するにはどうすればよいですか?

Firestore コレクションとサブコレクションを効果的に削除するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-26 15:30:03454ブラウズ

How to Delete Firestore Collections and Subcollections Effectively?

Firestore でのコレクションとサブコレクションの削除

問題ステートメント:

次の Firestore データベース内リストのコレクション。各リストには従業員と場所という 2 つのサブコレクションが含まれます。ユーザーが特定のリストを削除したい場合、リスト ドキュメントだけを削除してもサブコレクションは削除されません。この問題は、サブコレクションを含むドキュメントを削除しても、それらのサブコレクションは自動的に削除されないという Firestore ドキュメントの指示により発生します。

提案された解決策:

1。サブコレクションの反復削除:

  • 従業員および場所のサブコレクション内のすべてのドキュメントを取得します。
  • 取得した各ドキュメントを削除します。
  • リスト ドキュメントを削除します。

2. deleteCollection メソッドを使用します (非推奨):

  • Firestore deleteCollection メソッドは、コレクション内のすべてのドキュメントを再帰的に削除します。
  • メモリ エラーを避けるために、このメソッドは小さなコレクションに対してのみ使用してください。 .
  • この操作は信頼できるサーバー環境から実行してください。

再帰的削除用の Android コード:

次の Android コードは、次のことを示します。コレクションを再帰的に削除する方法:

<code class="java">private void deleteCollection(final CollectionReference collection, Executor executor) {
    Tasks.call(executor, () -> {
        int batchSize = 10;
        Query query = collection.orderBy(FieldPath.documentId()).limit(batchSize);
        List<DocumentSnapshot> deleted = deleteQueryBatch(query);

        while (deleted.size() >= batchSize) {
            DocumentSnapshot last = deleted.get(deleted.size() - 1);
            query = collection.orderBy(FieldPath.documentId()).startAfter(last.getId()).limit(batchSize);

            deleted = deleteQueryBatch(query);
        }

        return null;
    });
}

@WorkerThread
private List<DocumentSnapshot> deleteQueryBatch(final Query query) throws Exception {
    QuerySnapshot querySnapshot = Tasks.await(query.get());

    WriteBatch batch = query.getFirestore().batch();
    for (DocumentSnapshot snapshot : querySnapshot) {
        batch.delete(snapshot.getReference());
    }
    Tasks.await(batch.commit());

    return querySnapshot.getDocuments();
}</code>

以上がFirestore コレクションとサブコレクションを効果的に削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。