توضّح الأمثلة التالية كيفية حذف المستندات والحقول والمجموعات.
حذف المستندات
لحذف مستند، استخدِم 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/mysubcoll/mysubdoc
حتى إذا حذفت المستند الأصلي في /mycoll/mydoc
.
تظهر مستندات الأصل غير المتوفّرة في وحدة التحكّم، ولكنّها لا تظهر في نتائج البحث واللقطات.
إذا أردت حذف مستند وجميع المستندات ضِمن مجموعاته الفرعية، عليك إجراء ذلك يدويًا. لمزيد من المعلومات، يُرجى الاطّلاع على حذف المجموعات.
حذف الحقول
لحذف حقول معيّنة من مستند، استخدِم 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، يُرجى الاطّلاع على إدارة الاحتفاظ بالبيانات باستخدام سياسات TTL.
مهام الحذف المجمّع
يتيح Cloud Firestore العديد من الأدوات للحذف المجمّع. عليك اختيار أداة استنادًا إلى عدد المستندات التي تريد حذفها ومستوى إمكانية الضبط الذي تحتاجه.
بالنسبة إلى المهام الأصغر التي تتضمّن آلاف المستندات، استخدِم وحدة التحكّم أو واجهة سطر الأوامر (CLI) في Firebase. بالنسبة إلى المهام الأكبر حجمًا، قد تبدأ هذه الأدوات في تجاوز المهلة الزمنية وتتطلب منك تشغيلها عدة مرات.
وحدة التحكم
يمكنك حذف المستندات والمجموعات من صفحة Cloud Firestore في وحدة التحكّم. يؤدي حذف مستند من وحدة التحكّم إلى حذف جميع البيانات المتداخلة في هذا المستند، بما في ذلك أي مجموعات فرعية.
Firebase CLI
يمكنك أيضًا استخدام Firebase CLI لحذف المستندات والمجموعات. استخدِم الأمر التالي لحذف البيانات:
firebase firestore:delete --database=DATABASE_ID PATH
استبدِل DATABASE_ID بمعرّف قاعدة البيانات وPATH بمسار إلى مستند أو مجموعة.
بالنسبة إلى مهام الحذف الكبيرة (ملايين المستندات)، استخدِم أحد الخيارَين التاليَين:
الحذف المجمّع المُدار
تتيح Cloud Firestore حذف مجموعة واحدة أو أكثر من مجموعات البيانات بشكل مجمّع. لمزيد من المعلومات، يُرجى الاطّلاع على الحذف المجمّع للبيانات.
أداة ربط Dataflow
يمكنك استخدام Dataflow لإجراء عمليات مجمّعة على قاعدة البيانات. هذا الخيار هو الأكثر قابلية للضبط، ولكنه يتطلّب أيضًا إعدادًا أكثر من خيارات الحذف المجمّع الأخرى. يتضمّن منشور المدونة الخاص بمقدّمة حول أداة الربط Cloud Firestore مثالاً على حذف جميع المستندات في مجموعة.