Les exemples suivants montrent comment supprimer des documents, des champs et des collections.
Supprimer des documents
Pour supprimer un document, utilisez les méthodes delete()
spécifiques à la langue suivante :
Web
Utilisez la méthode deleteDoc()
.
import { doc, deleteDoc } from "firebase/firestore"; await deleteDoc(doc(db, "cities", "DC"));
Web
Utilisez la méthode delete()
.
db.collection("cities").doc("DC").delete().then(() => { console.log("Document successfully deleted!"); }).catch((error) => { console.error("Error removing document: ", error); });
Swift
Utilisez la méthode delete()
.
do { try await db.collection("cities").document("DC").delete() print("Document successfully removed!") } catch { print("Error removing document: \(error)") }
Objective-C
Utilisez la méthode deleteDocumentWithCompletion:
.
[[[self.db collectionWithPath:@"cities"] documentWithPath:@"DC"] deleteDocumentWithCompletion:^(NSError * _Nullable error) { if (error != nil) { NSLog(@"Error removing document: %@", error); } else { NSLog(@"Document successfully removed!"); } }];
Kotlin
Utilisez la méthode delete()
.
db.collection("cities").document("DC") .delete() .addOnSuccessListener { Log.d(TAG, "DocumentSnapshot successfully deleted!") } .addOnFailureListener { e -> Log.w(TAG, "Error deleting document", e) }
Java
Utilisez la méthode delete()
.
db.collection("cities").document("DC") .delete() .addOnSuccessListener(new OnSuccessListener<Void>() { @Override public void onSuccess(Void aVoid) { Log.d(TAG, "DocumentSnapshot successfully deleted!"); } }) .addOnFailureListener(new OnFailureListener() { @Override public void onFailure(@NonNull Exception e) { Log.w(TAG, "Error deleting document", e); } });
Dart
Utilisez la méthode delete()
.
db.collection("cities").doc("DC").delete().then( (doc) => print("Document deleted"), onError: (e) => print("Error updating document $e"), );
Java
Utilisez la méthode delete()
.
Python
Utilisez la méthode delete()
.
Python
Utilisez la méthode delete()
.
C++
Utilisez la méthode Delete()
.
db->Collection("cities").Document("DC").Delete().OnCompletion( [](const Future<void>& future) { if (future.error() == Error::kErrorOk) { std::cout << "DocumentSnapshot successfully deleted!" << std::endl; } else { std::cout << "Error deleting document: " << future.error_message() << std::endl; } });
Node.js
Utilisez la méthode delete()
.
Accéder
Utilisez la méthode Delete()
.
PHP
Utilisez la méthode delete()
.
Unity
Utilisez la méthode DeleteAsync()
.
DocumentReference cityRef = db.Collection("cities").Document("DC"); cityRef.DeleteAsync();
C#
Utilisez la méthode DeleteAsync()
.
Ruby
Utilisez la méthode delete()
.
Lorsque vous supprimez un document, Cloud Firestore ne supprime pas automatiquement les documents de ses sous-collections. Vous pouvez toujours accéder aux documents des sous-collections par référence.
Par exemple, vous pouvez accéder au document en suivant le chemin d'accès /mycoll/mydoc/mysubcoll/mysubdoc
même si vous supprimez le document ancêtre à l'emplacement /mycoll/mydoc
.
Des documents ancêtres inexistants apparaissent dans la console, mais ils n'apparaissent pas dans les résultats de requête ni dans les instantanés.
Si vous souhaitez supprimer un document et tous les documents de ses sous-collections, vous devez le faire manuellement. Pour plus d'informations, consultez la section Supprimer des collections.
Supprimer des champs
Pour supprimer des champs spécifiques d'un document, utilisez les méthodes FieldValue.delete()
spécifiques à la langue suivante lorsque vous mettez à jour un document :
Web
Utilisez la méthode deleteField()
.
import { doc, updateDoc, deleteField } from "firebase/firestore"; const cityRef = doc(db, 'cities', 'BJ'); // Remove the 'capital' field from the document await updateDoc(cityRef, { capital: deleteField() });
Web
Utilisez la méthode FieldValue.delete()
.
var cityRef = db.collection('cities').doc('BJ'); // Remove the 'capital' field from the document var removeCapital = cityRef.update({ capital: firebase.firestore.FieldValue.delete() });
Swift
Utilisez la méthode FieldValue.delete()
.
do { try await db.collection("cities").document("BJ").updateData([ "capital": FieldValue.delete(), ]) print("Document successfully updated") } catch { print("Error updating document: \(error)") }
Objective-C
Utilisez la méthode fieldValueForDelete:
.
[[[self.db collectionWithPath:@"cities"] documentWithPath:@"BJ"] updateData:@{ @"capital": [FIRFieldValue fieldValueForDelete] } completion:^(NSError * _Nullable error) { if (error != nil) { NSLog(@"Error updating document: %@", error); } else { NSLog(@"Document successfully updated"); } }];
Kotlin
Utilisez la méthode FieldValue.delete()
.
val docRef = db.collection("cities").document("BJ") // Remove the 'capital' field from the document val updates = hashMapOf<String, Any>( "capital" to FieldValue.delete(), ) docRef.update(updates).addOnCompleteListener { }
Java
Utilisez la méthode FieldValue.delete()
.
DocumentReference docRef = db.collection("cities").document("BJ"); // Remove the 'capital' field from the document Map<String,Object> updates = new HashMap<>(); updates.put("capital", FieldValue.delete()); docRef.update(updates).addOnCompleteListener(new OnCompleteListener<Void>() { // ... // ...
Dart
Utilisez la méthode FieldValue.delete()
.
final docRef = db.collection("cities").doc("BJ"); // Remove the 'capital' field from the document final updates = <String, dynamic>{ "capital": FieldValue.delete(), }; docRef.update(updates);
Java
Utilisez la méthode FieldValue.delete()
.
Python
Utilisez la méthode firestore.DELETE_FIELD
.
Python
Utilisez la méthode firestore.DELETE_FIELD
.
C++
Utilisez la méthode FieldValue::Delete()
.
DocumentReference doc_ref = db->Collection("cities").Document("BJ"); doc_ref.Update({{"capital", FieldValue::Delete()}}) .OnCompletion([](const Future<void>& future) { /*...*/ });
Node.js
Utilisez la méthode FieldValue.delete()
.
Accéder
Utilisez la méthode firestore.Delete
.
PHP
Utilisez la méthode FieldValue::deleteField()
.
Unity
Utilisez la méthode FieldValue.Delete
.
DocumentReference cityRef = db.Collection("cities").Document("BJ"); Dictionary<string, object> updates = new Dictionary<string, object> { { "Capital", FieldValue.Delete } };
C#
Utilisez la méthode FieldValue.Delete
.
Ruby
Utilisez la méthode firestore.field_delete
.
Supprimer des collections
Pour supprimer une collection ou une sous-collection entière dans Cloud Firestore, récupérez (lisez) tous les documents de la collection ou de la sous-collection et supprimez-les. Ce processus entraîne des coûts de lecture et de suppression. Si vos collections sont plus volumineuses, vous pouvez les supprimer en petits lots pour éviter les erreurs de mémoire insuffisante. Répétez le processus jusqu'à ce que vous ayez supprimé l'intégralité de la collection ou de la sous-collection.
La suppression d'une collection nécessite la coordination d'un nombre illimité de requêtes de suppression individuelles. Si vous devez supprimer des collections entières, faites-le uniquement depuis un environnement de serveur de confiance. Bien qu'il soit possible de supprimer une collection d'un client mobile ou Web, cela a des implications négatives en termes de sécurité et de performance.
Les extraits suivants sont simplifiés pour plus de clarté et n'incluent pas la gestion des erreurs, la sécurité, la suppression des sous-collections ni les optimisations des performances. Pour en savoir plus sur une méthode recommandée pour supprimer des collections en production, consultez la section Supprimer des collections et sous-collections.
Web
// Deleting collections from a Web client is not recommended.
Swift
// Deleting collections from an Apple client is not recommended.
Objective-C
// Deleting collections from an Apple client is not recommended.
Kotlin
// Deleting collections from an Android client is not recommended.
Java
// Deleting collections from an Android client is not recommended.
Dart
Il n'est pas recommandé de supprimer des collections depuis le client.
Java
Python
Python
C++
// This is not supported. Delete data using CLI as discussed below.
Node.js
Go
PHP
Unity
// This is not supported. Delete data using CLI as discussed below.
C#
Ruby
Supprimer des données avec des règles TTL
Une règle TTL désigne un champ donné comme heure d'expiration des documents d'un groupe de collections donné. Les opérations de suppression TTL sont comptabilisées dans vos coûts de suppression de documents.
Pour savoir comment définir le TTL, consultez Gérer la conservation des données avec des règles TTL.
Tâches de suppression groupée
Cloud Firestore est compatible avec plusieurs outils de suppression groupée. Vous devez sélectionner un outil en fonction du nombre de documents que vous devez supprimer et du niveau de configurabilité dont vous avez besoin.
Pour les tâches plus petites, de l'ordre de milliers de documents, utilisez la console ou la CLI Firebase. Pour les tâches plus importantes, ces outils peuvent commencer à expirer et vous obliger à les exécuter plusieurs fois.
Console
Vous pouvez supprimer des documents et des collections depuis la page Cloud Firestore de la console. La suppression d'un document depuis la console entraîne la suppression de toutes les données imbriquées dans ce document, y compris les sous-collections.
CLI Firebase
Vous pouvez également utiliser la CLI Firebase pour supprimer des documents et des collections. Utilisez la commande suivante pour supprimer des données :
firebase firestore:delete --database=DATABASE_ID PATH
Remplacez DATABASE_ID par l'ID de votre base de données et PATH par le chemin d'accès à un document ou à une collection.
Pour les grands jobs de suppression (millions de documents), utilisez l'une des méthodes suivantes :
Suppression groupée gérée
Cloud Firestore permet de supprimer plusieurs groupes de collections à la fois. Pour en savoir plus, consultez Supprimer des données de manière groupée.
Connecteur Dataflow
Vous pouvez utiliser Dataflow pour effectuer des opérations groupées sur votre base de données. Cette option est la plus configurable, mais elle nécessite également plus de configuration que les autres options de suppression groupée. L'article de blog sur le connecteur Cloud Firestore et l'introduction à Dataflow contient un exemple de suppression de tous les documents d'un groupe de collections.