Cloud Firestore تتيح استخدام فلاتر النطاق والمتباينة على حقول متعددة في طلب بحث واحد. يمكنك استخدام شروط النطاق والمتباينة على حقول متعددة وتبسيط عملية تطوير الـ تطبيق من خلال تفويض تنفيذ منطق ما بعد الفلترة إلى Cloud Firestore.
فلاتر النطاق والمتباينة على حقول متعددة
يستخدم طلب البحث التالي فلاتر النطاق على السكّان والكثافة لعرض جميع المدن التي يزيد عدد سكّانها عن 1,000,000 نسمة وتقلّ كثافتها السكانية عن 10,000 نسمة لكل وحدة مساحة.
الإصدار 9 من Web (وحدات نمطية)
const q = query(
collection(db, "cities"),
where('population', '>', 1000000),
where('density', '<', 10000),
);
Swift
let query = db.collection("cities")
.whereField("population", isGreaterThan: 1000000)
.whereField("density", isLessThan: 10000)
Objective-C
FIRQuery *query =
[[[[self.db collectionWithPath:@"cities"]
queryWhereField:@"population" isGreaterThan:@1000000]
queryWhereField:@"density" isLessThan:@10000];
Java Android
Query query = db.collection("cities")
.whereGreaterThan("population", 1000000)
.whereLessThan("density", 10000);
Kotlin+KTX Android
val query = db.collection("cities")
.whereGreaterThan("population", 1000000)
.whereLessThan("density", 10000)
متابعة
query := client.Collection("cities").
Where("population", ">", 1000000).
Where("density", "<", 10000)
جافا
db.collection("cities")
.whereGreaterThan("population", 1000000)
.whereLessThan("density", 10000);
Node.js
db.collection("cities")
.where('population', '>', 1000000),
.where('density', '<', 10000)
Python
from google.cloud import firestore
db = firestore.Client()
query = db.collection("cities")
.where("population", ">", 1000000)
.where("density", "<", 10000)
PHP
#C
لغة Ruby
query = cities_ref.where("population", ">", "1000000")
.where("density", "<", 10000)
C++
CollectionReference cities_ref = db->Collection("cities");
Query query = cities_ref.WhereGreaterThan("population", FieldValue::Integer(1000000))
.WhereLessThan("density", FieldValue::Integer(10000));
Unity
CollectionReference citiesRef = db.Collection("cities");
Query query = citiesRef.WhereGreaterThan("population", 1000000)
.WhereLessThan("density", 10000);
Dart
final citiesRef = FirebaseFirestore.instance.collection('cities')
final query = citiesRef.where("population", isGreaterThan: 1000000)
.where("density", isLessThan: 10000);
اعتبارات الفهرسة
قبل تنفيذ طلبات البحث، اطّلِع على طلبات البحث وCloud Firestore نموذج البيانات.
في Cloud Firestore، تحدّد عبارة ORDER BY في طلب البحث الفهارس التي
يمكن استخدامها لعرض نتائج طلب البحث. على سبيل المثال، يتطلّب طلب البحث ORDER BY a ASC, b ASC
فهرسًا مركّبًا على الحقلَين a ASC, b ASC.
لتحسين أداء طلبات بحث Cloud Firestore وتكلفتها، يمكنك تحسين ترتيب الحقول في الفهرس. لإجراء ذلك، تأكَّد من أنّ الفهرس مرتَّب من اليمين إلى اليسار بحيث يتم تقليل طلب البحث إلى مجموعة بيانات تمنع فحص إدخالات الفهرس غير الضرورية.
لنفترض أنّك تريد البحث في مجموعة من الموظفين والعثور على الموظفين في الولايات المتحدة الذين يزيد راتبهم عن 100,000 دولار أمريكي ويزيد عدد سنوات خبرتهم عن 0. استنادًا إلى فهمك لمجموعة البيانات، أنت تعلم أنّ شرط الراتب أكثر تحديدًا من شرط الخبرة. الفهرس المثالي الذي سيقلّل عدد عمليات فحص الفهرس هو (salary [...], experience [...]). وبالتالي، فإنّ طلب البحث الذي سيكون سريعًا وفعّالاً من حيث التكلفة هو الذي يرتب salary قبل experience ويبدو على النحو التالي:
جافا
db.collection("employees")
.whereGreaterThan("salary", 100000)
.whereGreaterThan("experience", 0)
.orderBy("salary")
.orderBy("experience");
Node.js
db.collection("employees")
.where("salary", ">", 100000)
.where("experience", ">", 0)
.orderBy("salary")
.orderBy("experience");
Python
db.collection("employees")
.where("salary", ">", 100000)
.where("experience", ">", 0)
.order_by("salary")
.order_by("experience");
أفضل الممارسات لتحسين الفهارس
عند تحسين الفهارس، يُرجى مراعاة أفضل الممارسات التالية.
ترتيب حقول الفهرس حسب المساواة، يليها حقل النطاق أو المتباينة الأكثر تحديدًا
Cloud Firestore تستخدم الحقول الموجودة في أقصى يسار الفهرس المركّب لاستيفاء قيود المساواة وقيود النطاق أو المتباينة، إن وُجدت، على الحقل الأول من طلب البحث orderBy() يمكن أن تقلّل هذه القيود عدد إدخالات الفهرس التي تفحصها Cloud Firestore Cloud Firestore تستخدم الحقول المتبقية
من الفهرس لاستيفاء قيود النطاق أو المتباينة الأخرى في طلب البحث. لا تقلّل هذه
القيود عدد إدخالات الفهرس التي تفحصها Cloud Firestore،
ولكنها تفلتر المستندات غير المطابقة حتى يتم تقليل عدد المستندات التي يتم
عرضها على العملاء.
لمزيد من المعلومات عن إنشاء فهارس فعّالة، اطّلِع على خصائص الفهرس.
ترتيب الحقول بترتيب تنازلي حسب مدى تحديد قيود طلب البحث
لضمان اختيار Cloud Firestore للفهرس الأمثل لطلب البحث،
حدِّد عبارة orderBy() التي ترتّب الحقول بترتيب تنازلي حسب مدى تحديد قيود طلب البحث. تطابق درجة التحديد الأعلى مجموعة فرعية أصغر من المستندات، بينما تطابق درجة التحديد الأدنى مجموعة فرعية أكبر من المستندات. تأكَّد من اختيار حقول النطاق أو المتباينة ذات درجة التحديد الأعلى في وقت سابق من ترتيب الفهرس مقارنةً بالحقول ذات درجة التحديد الأدنى.
للحدّ من عدد المستندات التي Cloud Firestore تفحصها وتعرضها عبر الشبكة، عليك دائمًا ترتيب الحقول بترتيب تنازلي حسب مدى تحديد قيود طلب البحث. إذا لم تكن مجموعة النتائج بالترتيب المطلوب وكان من المتوقّع أن تكون صغيرة، يمكنك تنفيذ منطق من جهة العميل لإعادة ترتيبها وفقًا لتوقعاتك بشأن الترتيب.
على سبيل المثال، لنفترض أنّك تريد البحث في مجموعة من الموظفين للعثور على الموظفين في الولايات المتحدة الذين يزيد راتبهم عن 100,000 دولار أمريكي وترتيب النتائج حسب سنة خبرة الموظف. إذا كنت تتوقّع أن يكون عدد الموظفين الذين تزيد رواتبهم عن 100,000 دولار أمريكي قليلاً، فإنّ الطريقة الأكثر فعالية لكتابة طلب البحث هي كما يلي:
جافا
db.collection("employees")
.whereGreaterThan("salary", 100000)
.orderBy("salary")
.get()
.addOnSuccessListener(new OnSuccessListener<QuerySnapshot>() {
@Override
public void onSuccess(QuerySnapshot queryDocumentSnapshots) {
// Order results by `experience`
}
});;
Node.js
const querySnapshot = await db.collection('employees')
.where("salary", ">", 100000)
.orderBy("salary")
.get();
// Order results by `experience`
Python
results = db.collection("employees")
.where("salary", ">", 100000)
.order_by("salary")
.stream()
// Order results by `experience`
في حين أنّ إضافة ترتيب على experience إلى طلب البحث ستؤدي إلى عرض مجموعة المستندات نفسها وتجنُّب إعادة ترتيب النتائج على أجهزة العملاء، قد يقرأ طلب البحث عددًا أكبر بكثير من إدخالات الفهرس غير الضرورية مقارنةً بطلب البحث السابق. يرجع ذلك إلى أنّ
Cloud Firestore يفضّل دائمًا فهرسًا تتطابق حقوله مع بادئة عبارة "
الترتيب حسب" في طلب البحث. إذا تمت إضافة experience إلى عبارة الترتيب حسب، ستختار Cloud Firestore الفهرس (experience [...], salary [...]) لحساب نتائج طلب البحث. بما أنّه ما مِن قيود أخرى على
experience, ستقرأ Cloud Firestore جميع إدخالات الفهرس في مجموعة
employees قبل تطبيق فلتر salary للعثور على مجموعة
النتائج النهائية. وهذا يعني أنّه سيتم قراءة إدخالات الفهرس التي لا تستوفي فلتر salary، ما يؤدي إلى زيادة وقت الاستجابة وتكلفة طلب البحث.
الأسعار
تتم فوترة طلبات البحث التي تتضمّن فلاتر النطاق والمتباينة على حقول متعددة استنادًا إلى المستندات التي تتم قراءتها وإدخالات الفهرس التي تتم قراءتها.
للحصول على معلومات مفصّلة، اطّلِع على صفحة الأسعار.
القيود
بالإضافة إلى قيود طلب البحث، يُرجى مراعاة القيود التالية قبل استخدام طلبات البحث التي تتضمّن فلاتر النطاق والمتباينة على حقول متعددة:
- لا تتوافق طلبات البحث التي تتضمّن فلاتر النطاق أو المتباينة على حقول المستند وقيود المساواة فقط على مفتاح المستند
(__name__). - Cloud Firestore تحدّ عدد حقول النطاق أو المتباينة بـ 10 حقول. يتم ذلك لمنع أن تصبح طلبات البحث مكلفة جدًا عند تنفيذها.
الخطوات التالية
- تعرَّف على كيفية تحسين طلبات البحث.
- تعرَّف على مزيد من المعلومات عن تنفيذ طلبات البحث البسيطة والمركّبة.
- تعرَّف على كيفية استخدام Cloud Firestore للفهارس.