下列範例說明如何刪除文件、欄位和集合。
刪除文件
如要刪除文件,請使用下列語言專屬的 delete() 方法:
Web
使用 deleteDoc() 方法:
import { doc, deleteDoc } from "firebase/firestore"; await deleteDoc(doc(db, "cities", "DC"));
Web
使用 delete() 方法:
db.collection("cities").doc("DC").delete().then(() => { console.log("Document successfully deleted!"); }).catch((error) => { console.error("Error removing document: ", error); });
Swift
使用 delete() 方法:
do { try await db.collection("cities").document("DC").delete() print("Document successfully removed!") } catch { print("Error removing document: \(error)") }
Objective-C
使用 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
使用 delete() 方法:
db.collection("cities").document("DC") .delete() .addOnSuccessListener { Log.d(TAG, "DocumentSnapshot successfully deleted!") } .addOnFailureListener { e -> Log.w(TAG, "Error deleting document", e) }
Java
使用 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
使用 delete() 方法:
db.collection("cities").doc("DC").delete().then( (doc) => print("Document deleted"), onError: (e) => print("Error updating document $e"), );
Java
使用 delete() 方法:
Python
使用 delete() 方法:
Python
使用 delete() 方法:
C++
使用 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
使用 delete() 方法:
Go
使用 Delete() 方法:
PHP
使用 delete() 方法:
Unity
使用 DeleteAsync() 方法:
DocumentReference cityRef = db.Collection("cities").Document("DC"); cityRef.DeleteAsync();
C#
使用 DeleteAsync() 方法:
Ruby
使用 delete() 方法:
刪除文件時,Cloud Firestore 不會自動刪除子集合中的文件。您還是可以透過參照存取子集合文件。舉例來說,即使您刪除 /mycoll/mydoc 的上層文件,仍可存取 /mycoll/mydoc/mysubcoll/mysubdoc 路徑的文件。
不存在的祖先文件會顯示在控制台中,但不會顯示在查詢結果和快照中。
如要刪除文件及其子集合中的所有文件,必須手動操作。詳情請參閱「刪除集合」一文。
刪除欄位
如要從文件中刪除特定欄位,請在更新文件時使用下列語言專屬的 FieldValue.delete() 方法:
Web
使用 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
使用 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
使用 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
使用 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
使用 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
使用 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
使用 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
使用 FieldValue.delete() 方法:
Python
使用 firestore.DELETE_FIELD 方法:
Python
使用 firestore.DELETE_FIELD 方法:
C++
使用 FieldValue::Delete() 方法:
DocumentReference doc_ref = db->Collection("cities").Document("BJ"); doc_ref.Update({{"capital", FieldValue::Delete()}}) .OnCompletion([](const Future<void>& future) { /*...*/ });
Node.js
使用 FieldValue.delete() 方法:
Go
使用 firestore.Delete 方法:
PHP
使用 FieldValue::deleteField() 方法:
Unity
使用 FieldValue.Delete 方法:
DocumentReference cityRef = db.Collection("cities").Document("BJ"); Dictionary<string, object> updates = new Dictionary<string, object> { { "Capital", FieldValue.Delete } };
C#
使用 FieldValue.Delete 方法:
Ruby
使用 firestore.field_delete 方法:
刪除集合
如要刪除 Cloud Firestore 中的整個集合或子集合,請先擷取 (讀取) 集合或子集合中的所有文件,然後刪除這些文件。這項程序會產生讀取和刪除費用。如果集合較大,建議分批刪除文件,以免發生記憶體不足錯誤。重複這個程序,直到刪除整個集合或子集合為止。
刪除集合時,需要協調處理數量不受限的個別刪除要求。如要刪除整個集合,請務必在信任的伺服器環境中執行這項操作。雖然可以從行動裝置/網頁用戶端刪除集合,但這麼做會對安全性與效能造成負面影響。
為求清楚,以下程式碼片段已簡化,不包含錯誤處理、安全性、刪除子集合或效能最佳化。如要進一步瞭解刪除正式版集合的建議做法,請參閱「刪除集合和子集合」。
網頁
// 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
不建議從用戶端刪除集合。
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
使用存留時間政策刪除資料
存留時間政策會將特定欄位指定為特定集合群組中文件的到期時間。TTL 刪除作業會計入文件刪除費用。
如要瞭解如何設定 TTL,請參閱「使用 TTL 政策管理資料保留時間」。
大量刪除工作
Cloud Firestore 支援多種大量刪除工具。請根據要刪除的文件數量和所需設定層級,選取適當工具。
如要處理數千份文件的小型工作,請使用控制台或 Firebase CLI。如果是較大的工作,這些工具可能會開始逾時,您需要多次執行工具。
控制台
您可以在控制台的「Cloud Firestore」頁面刪除文件和集合。從控制台刪除文件時,系統會刪除該文件中的所有巢狀資料,包括任何子集合。
Firebase CLI
您也可以使用 Firebase CLI 刪除文件和集合。使用下列指令刪除資料:
firebase firestore:delete  --database=DATABASE_ID PATH
將 DATABASE_ID 替換為資料庫 ID,並將 PATH 替換為文件或集合的路徑。
如要刪除大量文件 (數百萬份),請使用下列其中一種方法:
代管大量刪除
Cloud Firestore 支援大量刪除一或多個集合群組。 詳情請參閱「大量刪除資料」。
Dataflow 連接器
您可以使用 Dataflow 對資料庫執行大量作業。這個選項的彈性最高,但相較於其他大量刪除選項,設定作業也較為複雜。如需 Dataflow 簡介,請參閱這篇網誌文章,其中有刪除集合群組中所有文件的範例。Cloud Firestore