Firestore でのコレクションとサブコレクションの削除
Firestore は、コレクションとドキュメントを含む階層データ構造を提供します。コレクションはサブコレクションを保持し、複数レベルの入れ子を作成できます。特定のリストを削除する場合、サブコレクションを保持しながらリスト ID を削除できないため、問題が発生します。
再構築を行わない解決策:
この問題を回避するには、次のようにします。次の手順を使用できます:
この方法により、データベースの構造を損なうことなくリストと関連データが完全に削除されます。
大規模なコレクションに関する考慮事項:
大規模なコレクションを扱う場合は、潜在的なメモリ不足エラーを軽減するために、ドキュメントを小さなバッチに分けて削除することをお勧めします。削除プロセスは、コレクションまたはサブコレクション内のすべてのドキュメントが削除されるまで続行する必要があります。
削除操作に関する注意:
削除操作は技術的には可能ですが、Firebaseチームは、セキュリティとパフォーマンスに影響を及ぼす可能性があるため、その使用を強く推奨しません。これは、特に信頼できるサーバー環境から実行する場合、小さなコレクションを削除する場合にのみ推奨されます。
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 サイトの他の関連記事を参照してください。