| यह सिर्फ़ Cloud Firestore Enterprise वर्शन के लिए काम का है. |
इस पेज पर, MongoDB के साथ काम करने वाले Cloud Firestore और MongoDB के व्यवहार में अंतर के बारे में बताया गया है.
MongoDB के वर्शन के हिसाब से, काम करने वाली सुविधाओं के बारे में जानने के लिए, यहां जाएं:
- इस्तेमाल की जा सकने वाली सुविधाएं: 8.0
- इस्तेमाल की जा सकने वाली सुविधाएं: 7.0
- इस्तेमाल की जा सकने वाली सुविधाएं: 6.0
- इस्तेमाल की जा सकने वाली सुविधाएं: 5.0
कनेक्शन और डेटाबेस
- हर कनेक्शन को, MongoDB के साथ काम करने वाले एक Cloud Firestore डेटाबेस तक सीमित किया जाता है.
- डेटाबेस से कनेक्ट करने से पहले, उसे बनाना ज़रूरी है.
नामकरण
आपके डेटा मॉडल के हिस्सों के नाम रखने के लिए, यहां दिए गए अंतर लागू होते हैं.
संग्रह
__.*__से मेल खाने वाले कलेक्शन के नाम इस्तेमाल नहीं किए जा सकते.
फ़ील्ड
__.*__से मिलते-जुलते फ़ील्ड के नाम इस्तेमाल नहीं किए जा सकते.- फ़ील्ड के नाम खाली नहीं होने चाहिए.
दस्तावेज़
- दस्तावेज़ का साइज़ 4 MiB से ज़्यादा नहीं होना चाहिए.
- फ़ील्ड को नेस्ट करने के लेवल की तय सीमा 20 है. ऐरे और ऑब्जेक्ट टाइप वाले हर फ़ील्ड से, कुल डेप्थ में एक लेवल जुड़ जाता है.
_id
- दस्तावेज़
_id(टॉप-लेवल फ़ील्ड) एक ObjectId, String या 64-बिट पूर्णांक होना चाहिए. अन्य BSON टाइप काम नहीं करते. - खाली स्ट्रिंग ("") और 64-बिट 0 (0L) का इस्तेमाल नहीं किया जा सकता.
वैल्यू
- JavaScript, Symbol, DBPointer, और Undefined BSON टाइप इस्तेमाल नहीं किए जा सकते.
तारीख
- तारीख की वैल्यू,
[0001-01-01T00:00:00Z, 9999-12-31T23:59:59Z]के बीच होनी चाहिए.
Decimal128
NaN, पॉज़िटिव इनफ़िनिटी, और नेगेटिव इनफ़िनिटी वैल्यू को लिखने के समय कैननिकल किया जाता है.- Decimal128 पर अंकगणितीय कार्रवाइयां नहीं की जा सकतीं.
डबल-साइज़ बेड
NaNवैल्यू को लिखने के दौरान कैननिकल किया जाता है.
रेगुलर एक्सप्रेशन
- रेगुलर एक्सप्रेशन के विकल्प मान्य होने चाहिए ("i", "m", "s", "u" या "x"). साथ ही, इन्हें दोहराए बिना वर्णमाला के क्रम में दिया जाना चाहिए.
क्वेरी
- नैचुरल सॉर्ट ऑर्डर (सॉर्ट करने के लिए साफ़ तौर पर निर्देश नहीं देने वाली क्वेरी), इंसर्शन ऑर्डर या
_idके हिसाब से बढ़ते क्रम में नहीं है.
एग्रीगेशन
- एग्रीगेशन को 250 चरणों तक सीमित किया गया है.
$mergeऔर$outचरणों का इस्तेमाल नहीं किया जा सकता. इस्तेमाल की जा सकने वाली स्टेज और ऑपरेटर की पूरी सूची देखने के लिए, कमांड सेक्शन देखें.$lookupस्टेज में,letऔरpipelineफ़ील्ड काम नहीं करते.
लिखता है
updateयाfindAndModifyकी अपसर्ट सुविधा का इस्तेमाल करके, डॉलर के निशान ("$") से शुरू होने वाले नाम वाले दस्तावेज़ नहीं बनाए जा सकते.- पक्का करें कि आपकी कनेक्शन स्ट्रिंग में
retryWrites=falseशामिल हो. इसके अलावा, अपने ड्राइवर के हिसाब से सही तरीके का इस्तेमाल करें, ताकि यह पक्का किया जा सके कि ड्राइवर इस सुविधा का इस्तेमाल न करे. फिर से लिखने की सुविधा काम नहीं करती.
लेन-देन
स्नैपशॉट आइसोलेशन और सीरियलाइज़ेबल लेन-देन काम करते हैं.
डिफ़ॉल्ट रूप से, लेन-देन में स्नैपशॉट आइसोलेशन के साथ-साथ ऑप्टिमिस्टिक कॉन्करेंसी कंट्रोल का इस्तेमाल किया जाता है.
समस्या से जुड़ा डेटा देखने की अनुमति दें
MongoDB के साथ काम करने वाला Cloud Firestore,
snapshot,majority, औरlinearizableरीड कंसर्न के साथ काम करता है. डिफ़ॉल्ट वैल्यूsnapshotहोती है, जिसका मतलब स्नैपशॉट आइसोलेशन होता है.अगर ऐप्लिकेशन को डेटा में लगातार बदलाव करने की ज़रूरत है और उसे राइट स्क्यू की गड़बड़ियों को रोकना है, तो
linearizableका इस्तेमाल करें. अन्य वर्कलोड के लिए,snapshotसे परफ़ॉर्मेंस बेहतर हो सकती है और लेन-देन से जुड़ी समस्याएं कम हो सकती हैं.
किसी समस्या के बारे में शिकायत करें
- सिर्फ़
w: 'majority'औरw: 1राइट कंसर्न का इस्तेमाल किया जा सकता है.
पढ़ने से जुड़ी प्राथमिकता
- सिर्फ़
primary,primaryPreferred,primary_preferred,secondary_preferred, औरnearestसे जुड़ी समस्याओं को पढ़ा जा सकता है.
इंडेक्स
- वाइल्डकार्ड इंडेक्स का इस्तेमाल नहीं किया जा सकता.
- MongoDB के साथ काम करने वाला Cloud Firestore,
_idपर अपने-आप इंडेक्स नहीं बनाता. हालांकि, यह पक्का करता है कि किसी कलेक्शन में_idकी वैल्यू यूनीक हों. - मल्टी-की की सुविधा के बिना इंडेक्स, राइट ऑपरेशन के आधार पर अपने-आप मल्टी-की इंडेक्स में नहीं बदलते हैं. इंडेक्स बनाते समय, आपको मल्टी-की चालू करनी होगी. इस विकल्प को बदला नहीं जा सकता.
गड़बड़ियां
- Cloud Firestore with MongoDB compatibility और MongoDB के बीच, गड़बड़ी के कोड और मैसेज अलग-अलग हो सकते हैं.
निर्देश
यहां दी गई जानकारी से पता चलता है कि कुछ खास कमांड के लिए, अलग-अलग डिवाइसों पर अलग-अलग तरीके से काम किया जाता है.
- यहां दी गई टेबल में शामिल नहीं किए गए निर्देशों का इस्तेमाल नहीं किया जा सकता.
maxTimeMSको ज़्यादातर कमांड में इस्तेमाल किया जा सकता है, लेकिन इसे अनदेखा भी किया जा सकता है.
क्वेरी और लिखता है
| Command | ऐसे फ़ील्ड जिनका इस्तेमाल नहीं किया जा सकता |
|---|---|
|
|
|
|
|
|
|
|
|
मिटाने के स्टेटमेंट में:
|
|
|
|
|
|
|
|
|
|
(कुछ नहीं) |
लेन-देन और सेशन
| Command | ऐसे फ़ील्ड जिनका इस्तेमाल नहीं किया जा सकता |
|---|---|
|
|
|
|
|
(कुछ नहीं) |
एडमिनिस्ट्रेशन
| Command | ऐसे फ़ील्ड जिनका इस्तेमाल नहीं किया जा सकता | ज़रूरी जानकारी |
|---|---|---|
|
|
अगर filter दिया गया है, तो इसकी वैल्यू खाली होनी चाहिए. |
|
|
अगर authorizedCollections दिया गया है, तो इसकी वैल्यू 'गलत' होनी चाहिए. |
|
|
|
|
|
यह कमांड कोई कार्रवाई नहीं करती है. अगर capped दिया गया है, तो इसकी वैल्यू false होनी चाहिए. |
आगे क्या करना है
- क्विकस्टार्ट: डेटाबेस बनाना और उससे कनेक्ट करना को चलाएं.
- इस्तेमाल की जा सकने वाली सुविधाओं की पूरी सूची देखने के लिए, MongoDB के साथ काम करने वाले डेटा टाइप, ड्राइवर, और सुविधाएं लेख पढ़ें.