Cloud Firestore, एक ही क्वेरी में कई फ़ील्ड पर रेंज और असमानता वाले फ़िल्टर का इस्तेमाल करता है. एक से ज़्यादा फ़ील्ड के लिए, रेंज और असमानता की शर्तें तय की जा सकती हैं. साथ ही, Cloud Firestore को फ़िल्टर करने के बाद लागू होने वाले लॉजिक को लागू करने का काम सौंपकर, ऐप्लिकेशन डेवलपमेंट को आसान बनाया जा सकता है.
कई फ़ील्ड पर रेंज और असमानता वाले फ़िल्टर
नीचे दी गई क्वेरी में, जनसंख्या और घनत्व के लिए रेंज फ़िल्टर का इस्तेमाल किया गया है. इससे उन सभी शहरों की जानकारी मिलती है जहां जनसंख्या 1,000,000 से ज़्यादा है और जनसंख्या घनत्व, क्षेत्र की हर इकाई में 10,000 से कम है.
const q = query(
collection(db, "cities"),
where('population', '>', 1000000),
where('density', '<', 10000),
);
let query = db.collection("cities")
.whereField("population", isGreaterThan: 1000000)
.whereField("density", isLessThan: 10000)
FIRQuery *query =
[[[[self.db collectionWithPath:@"cities"]
queryWhereField:@"population" isGreaterThan:@1000000]
queryWhereField:@"density" isLessThan:@10000];
Query query = db.collection("cities")
.whereGreaterThan("population", 1000000)
.whereLessThan("density", 10000);
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);
db.collection("cities")
.where('population', '>', 1000000),
.where('density', '<', 10000)
from google.cloud import firestore
db = firestore.Client()
query = db.collection("cities")
.where("population", ">", 1000000)
.where("density", "<", 10000)
query = cities_ref.where("population", ">", "1000000")
.where("density", "<", 10000)
CollectionReference cities_ref = db->Collection("cities");
Query query = cities_ref.WhereGreaterThan("population", FieldValue::Integer(1000000))
.WhereLessThan("density", FieldValue::Integer(10000));
CollectionReference citiesRef = db.Collection("cities");
Query query = citiesRef.WhereGreaterThan("population", 1000000)
.WhereLessThan("density", 10000);
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 क्वेरी की परफ़ॉर्मेंस और लागत को ऑप्टिमाइज़ करने के लिए, इंडेक्स में फ़ील्ड के क्रम को ऑप्टिमाइज़ करें. ऐसा करने के लिए, पक्का करें कि आपका इंडेक्स, बाईं से दाईं ओर क्रम में हो, ताकि क्वेरी ऐसे डेटासेट में बदल जाए जो इंडेक्स की ग़ैर-ज़रूरी एंट्री को स्कैन करने से रोकता है.
मान लें कि आपको कर्मचारियों के कलेक्शन में खोज कर, अमेरिका के उन कर्मचारियों को ढूंढना है जिनकी सैलरी 1,00,000 डॉलर से ज़्यादा है और जिनके काम करने के अनुभव के सालों की संख्या 0 से ज़्यादा है. डेटासेट के बारे में अपनी समझ के आधार पर, आपको पता है कि सैलरी की सीमा, अनुभव की सीमा से ज़्यादा चुनिंदा है. इंडेक्स स्कैन की संख्या कम करने के लिए, सबसे सही इंडेक्स (salary [...], experience [...])
होगा. इसलिए, तेज़ और कम लागत वाली क्वेरी, salary
को experience
से पहले ऑर्डर करेगी. यह क्वेरी इस तरह दिखेगी:
db.collection("employees")
.whereGreaterThan("salary", 100000)
.whereGreaterThan("experience", 0)
.orderBy("salary")
.orderBy("experience");
db.collection("employees")
.where("salary", ">", 100000)
.where("experience", ">", 0)
.orderBy("salary")
.orderBy("experience");
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 के ज़रिए स्कैन किए गए और नेटवर्क पर दिखाए गए दस्तावेज़ों की संख्या कम करने के लिए, आपको हमेशा फ़ील्ड को क्वेरी के लिए चुनी गई शर्तों के हिसाब से, घटते क्रम में क्रम से लगाना चाहिए. अगर नतीजा सेट ज़रूरी क्रम में नहीं है और नतीजा सेट छोटा है, तो अपनी पसंद के मुताबिक क्रम में फिर से व्यवस्थित करने के लिए, क्लाइंट-साइड लॉजिक लागू किया जा सकता है.
उदाहरण के लिए, मान लें कि आपको अमेरिका के उन कर्मचारियों को ढूंढना है जिनकी सैलरी 1,00,000 डॉलर से ज़्यादा है. साथ ही, आपको नतीजों को कर्मचारी के अनुभव के हिसाब से क्रम में लगाना है. अगर आपको लगता है कि सिर्फ़ कुछ कर्मचारियों की सैलरी 1,00,000 डॉलर से ज़्यादा होगी, तो क्वेरी लिखने का सबसे सही तरीका यह है:
db.collection("employees")
.whereGreaterThan("salary", 100000)
.orderBy("salary")
.get()
.addOnSuccessListener(new OnSuccessListener<QuerySnapshot>() {
@Override
public void onSuccess(QuerySnapshot queryDocumentSnapshots) {
// Order results by `experience`
}
});;
const querySnapshot = await db.collection('employees')
.where("salary", ">", 100000)
.orderBy("salary")
.get();
// Order results by `experience`
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 salary
फ़िल्टर लागू करने से पहले, employees
कलेक्शन की सभी इंडेक्स एंट्री को पढ़ेगा, ताकि वह नतीजों का फ़ाइनल सेट ढूंढ सके. इसका मतलब है कि salary
फ़िल्टर से मेल न खाने वाली इंडेक्स एंट्री को अब भी पढ़ा जाता है. इससे क्वेरी के इंतज़ार का समय और लागत बढ़ जाती है.
कीमत
एक से ज़्यादा फ़ील्ड पर रेंज और असमानता वाले फ़िल्टर वाली क्वेरी के लिए, पढ़े गए दस्तावेज़ों और इंडेक्स की एंट्री के आधार पर शुल्क लिया जाता है.
ज़्यादा जानकारी के लिए, शुल्क पेज देखें.
सीमाएं
क्वेरी से जुड़ी सीमाओं के अलावा, एक से ज़्यादा फ़ील्ड पर रेंज और असमानता वाले फ़िल्टर के साथ क्वेरी इस्तेमाल करने से पहले, इन सीमाओं का ध्यान रखें:
- दस्तावेज़ के फ़ील्ड पर रेंज या असमानता वाले फ़िल्टर वाली क्वेरी और दस्तावेज़ की कुंजी
(__name__)
पर सिर्फ़ बराबरी की शर्तें काम नहीं करतीं. - Cloud Firestore, रेंज या असमानता वाले फ़ील्ड की संख्या को 10 तक सीमित करता है. ऐसा इसलिए किया जाता है, ताकि क्वेरी को चलाने में ज़्यादा खर्च न हो.
आगे क्या करना है
- अपनी क्वेरी ऑप्टिमाइज़ करने के बारे में जानें.
- साधारण और कंपाउंड क्वेरी करने के बारे में ज़्यादा जानें.
- जानें कि Cloud Firestore इंडेक्स का इस्तेमाल कैसे करता है.