MongoDB - अनुक्रमण
सूचकांक प्रश्नों के कुशल समाधान का समर्थन करते हैं। अनुक्रमित के बिना, MongoDB को क्वेरी विवरण से मेल खाने वाले दस्तावेज़ों को चुनने के लिए संग्रह के प्रत्येक दस्तावेज़ को स्कैन करना होगा। यह स्कैन अत्यधिक अक्षम है और बड़ी मात्रा में डेटा संसाधित करने के लिए MongoDB की आवश्यकता होती है।
इंडेक्स विशेष डेटा संरचनाएं हैं, जो डेटा के एक छोटे हिस्से को एक आसान-से-ट्रैवर्स फॉर्म में संग्रहीत करती हैं। सूचकांक एक विशिष्ट क्षेत्र या फ़ील्ड के सेट के मूल्य को संग्रहीत करता है, जो कि सूचकांक में निर्दिष्ट फ़ील्ड के मूल्य के अनुसार होता है।
CreateIndex () विधि
एक इंडेक्स बनाने के लिए, आपको MongoDB के createIndex () पद्धति का उपयोग करने की आवश्यकता है।
वाक्य - विन्यास
का मूल सिंटैक्स createIndex() विधि इस प्रकार है ()।
>db.COLLECTION_NAME.createIndex({KEY:1})
यहां कुंजी उस फ़ील्ड का नाम है, जिस पर आप इंडेक्स बनाना चाहते हैं और 1 आरोही क्रम के लिए है। अवरोही क्रम में सूचकांक बनाने के लिए आपको -1 का उपयोग करने की आवश्यकता है।
उदाहरण
>db.mycol.createIndex({"title":1})
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
>
में createIndex() विधि आप कई क्षेत्रों को पारित कर सकते हैं, कई क्षेत्रों पर सूचकांक बनाने के लिए।
>db.mycol.createIndex({"title":1,"description":-1})
>
यह विधि विकल्पों की सूची भी स्वीकार करती है (जो वैकल्पिक हैं)। निम्नलिखित सूची है -
पैरामीटर | प्रकार | विवरण |
---|---|---|
पृष्ठभूमि | बूलियन | इंडेक्स को पृष्ठभूमि में बनाता है ताकि एक इंडेक्स का निर्माण अन्य डेटाबेस गतिविधियों को अवरुद्ध न करें। पृष्ठभूमि में बनाने के लिए सही निर्दिष्ट करें। डिफ़ॉल्ट मान हैfalse। |
अद्वितीय | बूलियन | एक अद्वितीय सूचकांक बनाता है ताकि संग्रह दस्तावेजों के सम्मिलन को स्वीकार नहीं करेगा जहां सूचकांक कुंजी या चाबियाँ सूचकांक में मौजूदा मूल्य से मेल खाती हैं। एक अद्वितीय सूचकांक बनाने के लिए सही निर्दिष्ट करें। डिफ़ॉल्ट मान हैfalse। |
नाम | तार | सूचकांक का नाम। यदि अनिर्दिष्ट है, तो MongoDB अनुक्रमित फ़ील्ड और सॉर्ट क्रम के नामों को संक्षिप्त करके एक इंडेक्स नाम बनाता है। |
विरल | बूलियन | यदि सही है, तो सूचकांक केवल निर्दिष्ट क्षेत्र के साथ दस्तावेजों का संदर्भ देता है। ये सूचकांक कम जगह का उपयोग करते हैं लेकिन कुछ स्थितियों (विशेष रूप से प्रकार) में अलग तरह से व्यवहार करते हैं। डिफ़ॉल्ट मान हैfalse। |
expireAfterSeconds | पूर्णांक | इस संग्रह में दस्तावेज़ों को लंबे समय तक बनाए रखने के लिए TTL के रूप में सेकंड में एक मान निर्दिष्ट करता है। |
तौल | डाक्यूमेंट | वजन 1 से 99,999 तक की संख्या है और स्कोर के संदर्भ में अन्य अनुक्रमित क्षेत्रों के सापेक्ष क्षेत्र के महत्व को दर्शाता है। |
डिफ़ॉल्ट भाषा | तार | एक टेक्स्ट इंडेक्स के लिए, वह भाषा जो स्टॉप शब्दों की सूची और स्टेमर और टोकन के नियमों को निर्धारित करती है। डिफ़ॉल्ट मान हैEnglish। |
language_override | तार | टेक्स्ट इंडेक्स के लिए, दस्तावेज़ में फ़ील्ड का नाम निर्दिष्ट करें, जिसमें डिफ़ॉल्ट भाषा को ओवरराइड करने की भाषा है। डिफ़ॉल्ट मान भाषा है। |
DropIndex () विधि
आप MongoDB के ड्रॉपआईएंडएक्स () पद्धति का उपयोग करके एक विशेष सूचकांक को गिरा सकते हैं।
वाक्य - विन्यास
DropIndex () विधि का मूल सिंटैक्स इस प्रकार है ()।
>db.COLLECTION_NAME.dropIndex({KEY:1})
यहां कुंजी उस फ़ाइल का नाम है, जिस पर आप इंडेक्स बनाना चाहते हैं और 1 आरोही क्रम के लिए है। अवरोही क्रम में सूचकांक बनाने के लिए आपको -1 का उपयोग करने की आवश्यकता है।
उदाहरण
> db.mycol.dropIndex({"title":1})
{
"ok" : 0,
"errmsg" : "can't find index with key: { title: 1.0 }",
"code" : 27,
"codeName" : "IndexNotFound"
}
ड्रॉपइंडैक्स () विधि
यह विधि एक संग्रह पर कई (निर्दिष्ट) अनुक्रमित को हटा देती है।
वाक्य - विन्यास
DropIndexes () विधि का मूल सिंटैक्स निम्नानुसार है () -
>db.COLLECTION_NAME.dropIndexes()
उदाहरण
मान लें कि हमने नामांकित mycol संग्रह में 2 सूचकांक बनाए हैं जैसा कि नीचे दिखाया गया है -
> db.mycol.createIndex({"title":1,"description":-1})
निम्नलिखित उदाहरण mycol के उपरोक्त बनाए गए अनुक्रमित को निकालता है -
>db.mycol.dropIndexes({"title":1,"description":-1})
{ "nIndexesWas" : 2, "ok" : 1 }
>
GetIndexes () विधि
यह विधि सभी अनुक्रमणिकाओं के विवरण को संग्रह में वापस लौटाती है।
वाक्य - विन्यास
निम्नलिखित मूल वाक्यविन्यास getIndexes () विधि है -
db.COLLECTION_NAME.getIndexes()
उदाहरण
मान लें कि हमने नामांकित mycol संग्रह में 2 सूचकांक बनाए हैं जैसा कि नीचे दिखाया गया है -
> db.mycol.createIndex({"title":1,"description":-1})
निम्नलिखित उदाहरण संग्रह mycol में सभी अनुक्रमितों को पुनः प्राप्त करता है -
> db.mycol.getIndexes()
[
{
"v" : 2,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "test.mycol"
},
{
"v" : 2,
"key" : {
"title" : 1,
"description" : -1
},
"name" : "title_1_description_-1",
"ns" : "test.mycol"
}
]
>