FIRDatabaseReference पाना
डेटाबेस से डेटा पढ़ने या उसमें डेटा लिखने के लिए, आपको FIRDatabaseReference का कोई इंस्टेंस चाहिए:
Swift
var ref: DatabaseReference! ref = Database.database().reference()
Objective-C
@property (strong, nonatomic) FIRDatabaseReference *ref; self.ref = [[FIRDatabase database] reference];
सूचियां पढ़ना और उनमें डेटा लिखना
डेटा की सूची में डेटा जोड़ना
एक से ज़्यादा उपयोगकर्ताओं वाले ऐप्लिकेशन में, सूची में डेटा जोड़ने के लिए childByAutoId तरीके का इस्तेमाल करें. childByAutoId तरीका, तय किए गए Firebase रेफ़रंस में नया चाइल्ड जोड़ने पर, हर बार एक यूनीक कुंजी जनरेट करता है. सूची में मौजूद हर नए एलिमेंट के लिए, अपने-आप जनरेट होने वाली इन कुंजियों का इस्तेमाल करके, कई क्लाइंट एक ही जगह पर एक साथ चाइल्ड जोड़ सकते हैं. इससे, डेटा लिखने में कोई समस्या नहीं आती. childByAutoId से जनरेट होने वाली यूनीक कुंजी, टाइमस्टैंप पर आधारित होती है. इसलिए, सूची के आइटम, क्रम से अपने-आप व्यवस्थित हो जाते हैं.
चाइल्ड की अपने-आप जनरेट होने वाली कुंजी की वैल्यू पाने या चाइल्ड के लिए डेटा सेट करने के लिए, childByAutoId तरीके से मिले नए डेटा के रेफ़रंस का इस्तेमाल किया जा सकता है.
childByAutoId रेफ़रंस पर getKey को कॉल करने पर, अपने-आप जनरेट होने वाली कुंजी मिलती है.
अपने-आप जनरेट होने वाली इन कुंजियों का इस्तेमाल करके, डेटा स्ट्रक्चर को फ़्लैट किया जा सकता है. ज़्यादा जानकारी के लिए, डेटा फ़ैन-आउट उदाहरण देखें.
चाइल्ड इवेंट के बारे में सूचनाएं पाने की सुविधा चालू करना
चाइल्ड इवेंट, नोड के चाइल्ड पर होने वाली खास कार्रवाइयों के जवाब में ट्रिगर होते हैं. जैसे, childByAutoId तरीके से जोड़ा गया नया चाइल्ड या updateChildValues तरीके से अपडेट किया गया चाइल्ड.
| इवेंट टाइप | आम तौर पर इस्तेमाल |
|---|---|
FIRDataEventTypeChildAdded |
आइटम की सूचियां वापस पाएं या आइटम की सूची में जोड़े गए आइटम के बारे में सूचनाएं पाने की सुविधा चालू करें. यह इवेंट, मौजूदा हर चाइल्ड के लिए एक बार ट्रिगर होता है. इसके बाद, तय किए गए पाथ में नया चाइल्ड जोड़ने पर, यह फिर से ट्रिगर होता है. लिसनर को, नए चाइल्ड का डेटा वाला स्नैपशॉट पास किया जाता है. |
FIRDataEventTypeChildChanged |
सूची में मौजूद आइटम में किए गए बदलावों के बारे में सूचनाएं पाने की सुविधा चालू करें. चाइल्ड नोड में बदलाव होने पर, यह इवेंट ट्रिगर होता है. इसमें, चाइल्ड नोड के डिसेंडेंट में किए गए बदलाव भी शामिल हैं. इवेंट लिसनर को पास किए गए स्नैपशॉट में, चाइल्ड के लिए अपडेट किया गया डेटा होता है. |
FIRDataEventTypeChildRemoved |
सूची से हटाए गए आइटम के बारे में सूचनाएं पाने की सुविधा चालू करें. कोई इमीडिएट चाइल्ड हटाए जाने पर, यह इवेंट ट्रिगर होता है.कॉलबैक ब्लॉक को पास किए गए स्नैपशॉट में, हटाए गए चाइल्ड का डेटा होता है. |
FIRDataEventTypeChildMoved |
क्रम से लगाई गई सूची में मौजूद आइटम के क्रम में किए गए बदलावों के बारे में सूचनाएं पाने की सुविधा चालू करें.
अपडेट की वजह से चाइल्ड का क्रम बदलने पर, यह इवेंट ट्रिगर होता है. इसका इस्तेमाल, queryOrderedByChild
या queryOrderedByValue से क्रम से लगाए गए डेटा के साथ किया जाता है.
|
इन सभी का इस्तेमाल, डेटाबेस में मौजूद किसी खास नोड में किए गए बदलावों के बारे में सूचनाएं पाने के लिए किया जा सकता है. उदाहरण के लिए, सोशल ब्लॉगिंग ऐप्लिकेशन, पोस्ट की टिप्पणियों में होने वाली गतिविधि की निगरानी करने के लिए, इन तरीकों का एक साथ इस्तेमाल कर सकता है. जैसा कि यहां दिखाया गया है:
Swift
// Listen for new comments in the Firebase database commentsRef.observe(.childAdded, with: { (snapshot) -> Void in self.comments.append(snapshot) self.tableView.insertRows( at: [IndexPath(row: self.comments.count - 1, section: self.kSectionComments)], with: UITableView.RowAnimation.automatic ) }) // Listen for deleted comments in the Firebase database commentsRef.observe(.childRemoved, with: { (snapshot) -> Void in let index = self.indexOfMessage(snapshot) self.comments.remove(at: index) self.tableView.deleteRows( at: [IndexPath(row: index, section: self.kSectionComments)], with: UITableView.RowAnimation.automatic ) })
Objective-C
// Listen for new comments in the Firebase database [_commentsRef observeEventType:FIRDataEventTypeChildAdded withBlock:^(FIRDataSnapshot *snapshot) { [self.comments addObject:snapshot]; [self.tableView insertRowsAtIndexPaths:@[ [NSIndexPath indexPathForRow:self.comments.count - 1 inSection:kSectionComments] ] withRowAnimation:UITableViewRowAnimationAutomatic]; }]; // Listen for deleted comments in the Firebase database [_commentsRef observeEventType:FIRDataEventTypeChildRemoved withBlock:^(FIRDataSnapshot *snapshot) { int index = [self indexOfMessage:snapshot]; [self.comments removeObjectAtIndex:index]; [self.tableView deleteRowsAtIndexPaths:@[[NSIndexPath indexPathForRow:index inSection:kSectionComments]] withRowAnimation:UITableViewRowAnimationAutomatic]; }];
वैल्यू इवेंट के बारे में सूचनाएं पाने की सुविधा चालू करना
डेटा की सूचियां पढ़ने के लिए, चाइल्ड इवेंट के बारे में सूचनाएं पाने की सुविधा चालू करने का सुझाव दिया जाता है. हालांकि, कुछ स्थितियों में सूची के रेफ़रंस पर वैल्यू इवेंट के बारे में सूचनाएं पाने की सुविधा चालू करना काम का होता है.
डेटा की सूची में FIRDataEventTypeValue ऑब्ज़र्वर जोड़ने पर, डेटा की पूरी सूची, DataSnapshot के तौर पर दिखेगी. इसके बाद, अलग-अलग चाइल्ड को ऐक्सेस करने के लिए, इस सूची को लूप किया जा सकता है.
क्वेरी के लिए सिर्फ़ एक मैच होने पर भी, स्नैपशॉट एक सूची होती है. इसमें सिर्फ़ एक आइटम होता है. आइटम को ऐक्सेस करने के लिए, आपको नतीजे को लूप करना होगा:
Swift
_commentsRef.observe(.value) { snapshot in for child in snapshot.children { ... } }
Objective-C
[_commentsRef observeEventType:FIRDataEventTypeValue withBlock:^(FIRDataSnapshot *snapshot) { // Loop over children NSEnumerator *children = [snapshot children]; FIRDataSnapshot *child; while (child = [children nextObject]) { // ... } }];
यह पैटर्न तब काम का हो सकता है, जब आपको सूची के सभी चाइल्ड को एक ही कार्रवाई में फ़ेच करना हो. इसके बजाय, चाइल्ड जोड़े जाने के इवेंट के बारे में सूचनाएं पाने की सुविधा चालू करना बेहतर है.
डेटा को क्रम से लगाना और फ़िल्टर करना
आप डेटा को कुंजी, वैल्यू या चाइल्ड की वैल्यू के हिसाब से क्रम से लगाने के लिए Realtime Database FIRDatabaseQuery क्लास का इस्तेमाल कर सकते हैं. क्रम से लगाए गए नतीजों को, नतीजों की तय संख्या या कुंजियों या वैल्यू की रेंज के हिसाब से फ़िल्टर भी किया जा सकता है.
डेटा को क्रम से लगाना
क्रम से लगाया गया डेटा वापस पाने के लिए, सबसे पहले क्रम से लगाने के किसी एक तरीके को तय करें. इससे यह तय किया जा सकेगा कि नतीजों को किस क्रम में लगाया जाए:
| तरीका | इस्तेमाल |
|---|---|
queryOrderedByKey
| नतीजों को चाइल्ड की कुंजियों के हिसाब से क्रम से लगाएं. |
queryOrderedByValue |
नतीजों को चाइल्ड की वैल्यू के हिसाब से क्रम से लगाएं. |
queryOrderedByChild |
नतीजों को तय की गई चाइल्ड कुंजी या नेस्ट किए गए चाइल्ड पाथ की वैल्यू के हिसाब से क्रम से लगाएं. |
एक बार में, क्रम से लगाने का सिर्फ़ एक तरीका इस्तेमाल किया जा सकता है. एक ही क्वेरी में, क्रम से लगाने के किसी तरीके को एक से ज़्यादा बार कॉल करने पर, गड़बड़ी होती है.
यहां दिए गए उदाहरण में बताया गया है कि किसी उपयोगकर्ता की सबसे लोकप्रिय पोस्ट की सूची को, उन्हें मिले स्टार की संख्या के हिसाब से क्रम से कैसे लगाया जा सकता है:
Swift
// My top posts by number of stars let myTopPostsQuery = ref.child("user-posts").child(getUid()).queryOrdered(byChild: "starCount")
Objective-C
// My top posts by number of stars FIRDatabaseQuery *myTopPostsQuery = [[[self.ref child:@"user-posts"] child:[super getUid]] queryOrderedByChild:@"starCount"];
यह क्वेरी, डेटाबेस में मौजूद पाथ से उपयोगकर्ता की पोस्ट वापस पाती है. यह काम, उपयोगकर्ता की आईडी के आधार पर किया जाता है. साथ ही, हर पोस्ट को मिले स्टार की संख्या के हिसाब से, पोस्ट को क्रम से लगाया जाता है. आईडी को इंडेक्स कुंजियों के तौर पर इस्तेमाल करने की इस तकनीक को डेटा फ़ैन आउट कहा जाता है. इसके बारे में ज़्यादा जानने के लिए, अपने डेटाबेस का स्ट्रक्चर बनानालेख पढ़ें.
queryOrderedByChild तरीके को कॉल करने पर, उस चाइल्ड कुंजी के बारे में जानकारी मिलती है जिसके हिसाब से नतीजों को क्रम से लगाया जाता है. इस उदाहरण में, पोस्ट को हर पोस्ट में मौजूद
"starCount" चाइल्ड की वैल्यू के हिसाब से क्रम से लगाया गया है. क्वेरी को नेस्ट किए गए चाइल्ड के हिसाब से भी क्रम से लगाया जा सकता है. ऐसा तब किया जा सकता है, जब आपके पास इस तरह का डेटा हो:
"posts": {
"ts-functions": {
"metrics": {
"views" : 1200000,
"likes" : 251000,
"shares": 1200,
},
"title" : "Why you should use TypeScript for writing Cloud Functions",
"author": "Doug",
},
"android-arch-3": {
"metrics": {
"views" : 900000,
"likes" : 117000,
"shares": 144,
},
"title" : "Using Android Architecture Components with Firebase Realtime Database (Part 3)",
"author": "Doug",
}
},इस मामले में, हम अपनी सूची के एलिमेंट को metrics कुंजी के तहत नेस्ट की गई वैल्यू के हिसाब से क्रम से लगा सकते हैं. इसके लिए, queryOrderedByChild कॉल में नेस्ट किए गए चाइल्ड का रिलेटिव पाथ तय करना होगा.
Swift
let postsByMostPopular = ref.child("posts").queryOrdered(byChild: "metrics/views")
Objective-C
FIRDatabaseQuery *postsByMostPopular = [[ref child:@"posts"] queryOrderedByChild:@"metrics/views"];
अन्य तरह के डेटा को क्रम से लगाने के बारे में ज़्यादा जानने के लिए, क्वेरी के डेटा को क्रम से कैसे लगाया जाता है लेख पढ़ें.
डेटा फ़िल्टर करना
डेटा को फ़िल्टर करने के लिए, क्वेरी बनाते समय, सीमा या रेंज के किसी भी तरीके को क्रम से लगाने के किसी तरीके के साथ जोड़ा जा सकता है.
| तरीका | इस्तेमाल |
|---|---|
queryLimitedToFirst |
नतीजों की क्रम से लगाई गई सूची की शुरुआत से, वापस पाने के लिए आइटम की ज़्यादा से ज़्यादा संख्या सेट करता है. |
queryLimitedToLast |
नतीजों की क्रम से लगाई गई सूची के आखिर से, वापस पाने के लिए आइटम की ज़्यादा से ज़्यादा संख्या सेट करता है. |
queryStartingAtValue |
क्रम से लगाने के लिए चुने गए तरीके के आधार पर, तय की गई कुंजी या वैल्यू से ज़्यादा या उसके बराबर वाले आइटम वापस पाएं. |
queryStartingAfterValue |
क्रम से लगाने के लिए चुने गए तरीके के आधार पर, तय की गई कुंजी या वैल्यू से ज़्यादा वाले आइटम वापस पाएं. |
queryEndingAtValue |
क्रम से लगाने के लिए चुने गए तरीके के आधार पर, तय की गई कुंजी या वैल्यू से कम या उसके बराबर वाले आइटम वापस पाएं. |
queryEndingBeforeValue |
क्रम से लगाने के लिए चुने गए तरीके के आधार पर, तय की गई कुंजी या वैल्यू से कम वाले आइटम वापस पाएं. |
queryEqualToValue |
क्रम से लगाने के लिए चुने गए तरीके के आधार पर, तय की गई कुंजी या वैल्यू के बराबर वाले आइटम वापस पाएं. |
क्रम से लगाने के तरीकों के उलट, सीमा या रेंज के कई फ़ंक्शन को जोड़ा जा सकता है.
उदाहरण के लिए, नतीजों को वैल्यू की तय रेंज तक सीमित करने के लिए, queryStartingAtValue और queryEndingAtValue तरीकों को जोड़ा जा सकता है.
नतीजों की संख्या सीमित करना
queryLimitedToFirst और queryLimitedToLast तरीकों का इस्तेमाल करके, किसी दिए गए कॉलबैक के लिए सिंक किए जाने वाले चाइल्ड की ज़्यादा से ज़्यादा संख्या सेट की जा सकती है. उदाहरण के लिए, अगर queryLimitedToFirst का इस्तेमाल करके 100 की सीमा सेट की जाती है, तो आपको शुरुआती तौर पर सिर्फ़ 100 FIRDataEventTypeChildAdded कॉलबैक मिलते हैं. अगर आपके Firebase डेटाबेस में 100 से कम आइटम सेव हैं, तो हर आइटम के लिए FIRDataEventTypeChildAdded कॉलबैक ट्रिगर होता है.
आइटम में बदलाव होने पर, आपको उन आइटम के लिए FIRDataEventTypeChildAdded कॉलबैक मिलते हैं जो क्वेरी में शामिल होते हैं. साथ ही, उन आइटम के लिए FIRDataEventTypeChildRemoved कॉलबैक मिलते हैं जो क्वेरी से बाहर हो जाते हैं. इससे, आइटम की कुल संख्या 100 बनी रहती है.
यहां दिए गए उदाहरण में बताया गया है कि ब्लॉगिंग ऐप्लिकेशन, सभी उपयोगकर्ताओं की सबसे नई 100 पोस्ट की सूची कैसे वापस पा सकता है:
Swift
// Last 100 posts, these are automatically the 100 most recent // due to sorting by push() keys let recentPostsQuery = (ref?.child("posts").queryLimited(toFirst: 100))!
Objective-C
// Last 100 posts, these are automatically the 100 most recent // due to sorting by push() keys FIRDatabaseQuery *recentPostsQuery = [[self.ref child:@"posts"] queryLimitedToFirst:100];
कुंजी या वैल्यू के हिसाब से फ़िल्टर करना
क्वेरी के लिए, शुरुआती, आखिरी, और इक्विवेलंस पॉइंट तय करने के लिए, queryStartingAtValue, queryStartingAfterValue, queryEndingAtValue, queryEndingBeforeValue, और queryEqualToValue का इस्तेमाल किया जा सकता है. यह डेटा को पेज में बांटने या उन आइटम को ढूंढने के लिए काम का हो सकता है जिनके चाइल्ड की वैल्यू तय की गई वैल्यू के बराबर हो.
क्वेरी के डेटा को क्रम से कैसे लगाया जाता है
इस सेक्शन में बताया गया है कि FIRDatabaseQuery क्लास में, क्रम से लगाने के हर तरीके से डेटा को कैसे क्रम से लगाया जाता है.
queryOrderedByKey
अपने डेटा को क्रम से लगाने के लिए, queryOrderedByKey का इस्तेमाल करने पर, डेटा को कुंजी के हिसाब से बढ़ते क्रम में दिखाया जाता है.
- जिन चाइल्ड की कुंजी को 32-बिट इंटिजर के तौर पर पार्स किया जा सकता है वे सबसे पहले दिखते हैं. इन्हें बढ़ते क्रम में लगाया जाता है.
- जिन चाइल्ड की कुंजी की वैल्यू स्ट्रिंग होती है वे इसके बाद दिखते हैं. इन्हें लेक्सिकोग्राफ़िक तरीके से बढ़ते क्रम में लगाया जाता है.
queryOrderedByValue
queryOrderedByValue का इस्तेमाल करने पर, चाइल्ड को उनकी वैल्यू के हिसाब से क्रम से लगाया जाता है. क्रम से लगाने के मानदंड, queryOrderedByChild में इस्तेमाल किए गए मानदंडों के जैसे ही होते हैं. हालांकि, इसमें तय की गई चाइल्ड कुंजी की वैल्यू के बजाय, नोड की वैल्यू का इस्तेमाल किया जाता है.
queryOrderedByChild
queryOrderedByChild का इस्तेमाल करने पर, तय की गई चाइल्ड कुंजी वाला डेटा इस तरह क्रम से लगाया जाता है:
- जिन चाइल्ड के लिए, तय की गई चाइल्ड कुंजी की वैल्यू
nilहोती है वे सबसे पहले दिखते हैं. - जिन चाइल्ड के लिए, तय की गई चाइल्ड कुंजी की वैल्यू
falseहोती है वे इसके बाद दिखते हैं. अगर कई चाइल्ड की वैल्यूfalseहै, तो उन्हें कुंजी के हिसाब से लेक्सिकोग्राफ़िक तरीके से क्रम से लगाया जाता है. - जिन चाइल्ड के लिए, तय की गई चाइल्ड कुंजी की वैल्यू
trueहोती है वे इसके बाद दिखते हैं. अगर कई चाइल्ड की वैल्यूtrueहै, तो उन्हें कुंजी के हिसाब से लेक्सिकोग्राफ़िक तरीके से क्रम से लगाया जाता है. - जिन चाइल्ड की वैल्यू संख्या में होती है वे इसके बाद दिखते हैं. इन्हें बढ़ते क्रम में लगाया जाता है. अगर तय किए गए चाइल्ड नोड के लिए, कई चाइल्ड की वैल्यू एक जैसी है, तो उन्हें कुंजी के हिसाब से क्रम से लगाया जाता है.
- स्ट्रिंग, संख्याओं के बाद दिखती हैं. इन्हें लेक्सिकोग्राफ़िक तरीके से बढ़ते क्रम में लगाया जाता है . अगर तय किए गए चाइल्ड नोड के लिए, कई चाइल्ड की वैल्यू एक जैसी है, तो उन्हें कुंजी के हिसाब से लेक्सिकोग्राफ़िक तरीके से क्रम से लगाया जाता है.
- ऑब्जेक्ट सबसे आखिर में दिखते हैं. इन्हें कुंजी के हिसाब से लेक्सिकोग्राफ़िक तरीके से बढ़ते क्रम में लगाया जाता है.
लिसनर हटाना
ViewController से बाहर निकलने पर, ऑब्ज़र्वर अपने-आप डेटा सिंक करना बंद नहीं करते. अगर किसी ऑब्ज़र्वर को सही तरीके से नहीं हटाया जाता है, तो वह लोकल मेमोरी में डेटा सिंक करता रहता है. साथ ही, इवेंट हैंडलर क्लोज़र में कैप्चर किए गए सभी ऑब्जेक्ट को बनाए रखता है. इससे मेमोरी लीक हो सकती है. जब किसी ऑब्ज़र्वर की ज़रूरत न हो, तो उससे जुड़े FIRDatabaseHandle को removeObserverWithHandle तरीके में पास करके उसे हटाएं.
किसी रेफ़रंस में कॉलबैक ब्लॉक जोड़ने पर, FIRDatabaseHandle वापस मिलता है.
इन हैंडल का इस्तेमाल, कॉलबैक ब्लॉक को हटाने के लिए किया जा सकता है.
अगर डेटाबेस रेफ़रंस में कई लिसनर जोड़े गए हैं, तो इवेंट ट्रिगर होने पर, हर लिसनर को कॉल किया जाता है. उस जगह पर डेटा सिंक करना बंद करने के लिए, आपको removeAllObservers तरीके को कॉल करके, किसी जगह पर मौजूद सभी ऑब्ज़र्वर हटाने होंगे.
किसी लिसनर पर removeObserverWithHandle या removeAllObservers को कॉल करने पर, उसके चाइल्ड नोड पर रजिस्टर किए गए लिसनर अपने-आप नहीं हटते. उन्हें हटाने के लिए, आपको उन रेफ़रंस या हैंडल को भी ट्रैक करना होगा.