توضّح الأمثلة التالية كيفية حذف المستندات والحقول والمجموعات.
حذف المستندات
لحذف مستند، استخدِم طرق 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+KTX
استخدِم طريقة 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"), );
جافا
استخدِم طريقة 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()
:
انتقال
استخدِم طريقة 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+KTX
استخدِم طريقة 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);
جافا
استخدام الطريقة 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()
:
انتقال
استخدام الطريقة 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+KTX
// Deleting collections from an Android client is not recommended.
Java
// Deleting collections from an Android client is not recommended.
Dart
لا يُنصح بحذف المجموعات من البرنامج.
جافا
Python
Python
C++
// This is not supported. Delete data using CLI as discussed below.
Node.js
انتقال
PHP
Unity
// This is not supported. Delete data using CLI as discussed below.
#C
لغة Ruby
حذف البيانات باستخدام واجهة برمجة التطبيقات Firebase CLI
يمكنك أيضًا استخدام واجهة برمجة التطبيقات Firebase CLI لحذف المستندات والمجموعات. استخدِم الأمر التالي لحذف البيانات:
firebase firestore:delete [options] <<path>>
حذف البيانات باستخدام وحدة التحكّم
يمكنك حذف المستندات والمجموعات من صفحة Cloud Firestore في وحدة التحكّم. يؤدي حذف مستند من وحدة التحكّم إلى حذف جميع البيانات المُدمجة في ذلك المستند، بما في ذلك أي مجموعات فرعية.
حذف البيانات باستخدام سياسات مدة البقاء (TTL)
تعين سياسة TTL حقلاً معينًا على أنه وقت انتهاء صلاحية المستندات الموجودة في مجموعة مجموعات معينة. يتم احتساب عمليات حذف مدة البقاء (TTL) ضمن تكاليف حذف المستندات.
للحصول على معلومات عن ضبط مهلة "وقت الاسترجاع"، يُرجى الاطّلاع على المقالة إدارة الاحتفاظ بالبيانات باستخدام سياسات "وقت الاسترجاع".
للاطّلاع على مزيد من المعلومات حول رموز الأخطاء وكيفية حلّ مشاكل وقت الاستجابة عند حذف البيانات، يمكنك الاطّلاع على صفحة تحديد المشاكل وحلّها.
حذف البيانات باستخدام Dataflow
تُعدّ أداة Dataflow أداة رائعة لإجراء عمليات مجمّعة على قاعدة بيانات Firestore. تحتوي مقالة المدونة التي تقدّم مقدمة عن موصل Firebase لخدمة Dataflow على مثال لحذف جميع المستندات في مجموعة مجموعات.