MongoDB में, db.collection.unhideIndex()
विधि एक छिपी हुई अनुक्रमणिका को खोलती है।
एक हिडन इंडेक्स वह होता है जो क्वेरी प्लानर से छिपा होता है। जब आप किसी इंडेक्स को दिखाते हैं, तो वह क्वेरी प्लानर से छिपा नहीं रहता, और वह तुरंत उपयोग के लिए उपलब्ध हो जाता है।
उदाहरण
मान लीजिए हमारे पास pets
. नामक संग्रह है , और हम इसे हिडन इंडेक्स के लिए जांचना चाहते हैं। हम संग्रह पर सभी अनुक्रमणिका वापस करने के लिए निम्न क्वेरी चला सकते हैं:
db.pets.getIndexes()
परिणाम:
[ { "v" : 2, "key" : { "_id" : 1 }, "name" : "_id_" }, { "v" : 2, "key" : { "name" : 1, "type" : -1 }, "name" : "idx_name_1_type_-1" }, { "v" : 2, "key" : { "weight" : -1 }, "name" : "idx_weight_-1", "hidden" : true } ]
हम देख सकते हैं कि तीन सूचकांक हैं। तीसरा छिपा हुआ है। हम जानते हैं कि, क्योंकि इसमें "hidden" : true
. है ।
वह अनुक्रमणिका weight
. पर है खेत। जब हम क्वेरी प्लान के माध्यम से कोई क्वेरी चलाते हैं जो weight
. को क्वेरी करती है फ़ील्ड, हम देखेंगे कि यह अनुक्रमणिका का उपयोग नहीं करता है।
उदाहरण:
db.pets.find( { weight: { $gt: 10 } } ).explain()
परिणाम:
{ "queryPlanner" : { "plannerVersion" : 1, "namespace" : "PetHouse.pets", "indexFilterSet" : false, "parsedQuery" : { "weight" : { "$gt" : 10 } }, "queryHash" : "CEB852E7", "planCacheKey" : "851FBDB5", "winningPlan" : { "stage" : "COLLSCAN", "filter" : { "weight" : { "$gt" : 10 } }, "direction" : "forward" }, "rejectedPlans" : [ ] }, "ok" : 1 }
हम देख सकते हैं कि इसने COLLSCAN
किया था (एक संग्रह स्कैन), जिसका अर्थ है कि उसने अनुक्रमणिका का उपयोग नहीं किया।
सूचकांक दिखाएं
हम unhideIndex()
. का उपयोग कर सकते हैं सूचकांक को उजागर करने की विधि। यह विधि सूचकांक के नाम या उसके प्रमुख पैटर्न को एक पैरामीटर के रूप में स्वीकार करती है ताकि यह निर्दिष्ट किया जा सके कि किस सूचकांक को दिखाना है।
उदाहरण:
db.pets.unhideIndex("idx_weight_-1")
आउटपुट:
{ "hidden_old" : true, "hidden_new" : false, "ok" : 1 }
unhideIndex()
. का आउटपुट विधि hidden
. के लिए पुराना मान प्रदर्शित करती है फ़ील्ड (इस मामले में true
) और नया मान (इस मामले में false
)।
हालांकि, अगर हम पहले से छिपी हुई अनुक्रमणिका (या पहले से छिपी हुई अनुक्रमणिका को छिपाते हैं) को खोलते हैं, तो ये प्रदर्शित नहीं होती हैं, और हमें केवल निम्नलिखित मिलते हैं:
{ "ok" : 1 }
भले ही, अनुक्रमणिका अब छिपी नहीं है।
क्वेरी प्लान की दोबारा जांच करें
आइए पिछली क्वेरी को फिर से चलाते हैं यह देखने के लिए कि क्वेरी योजना अब कैसी दिखती है।
db.pets.find( { weight: { $gt: 10 } } ).explain()
परिणाम:
{ "queryPlanner" : { "plannerVersion" : 1, "namespace" : "PetHouse.pets", "indexFilterSet" : false, "parsedQuery" : { "weight" : { "$gt" : 10 } }, "queryHash" : "CEB852E7", "planCacheKey" : "851FBDB5", "winningPlan" : { "stage" : "FETCH", "inputStage" : { "stage" : "IXSCAN", "keyPattern" : { "weight" : -1 }, "indexName" : "idx_weight_-1", "isMultiKey" : false, "multiKeyPaths" : { "weight" : [ ] }, "isUnique" : false, "isSparse" : false, "isPartial" : false, "indexVersion" : 2, "direction" : "forward", "indexBounds" : { "weight" : [ "[inf.0, 10.0)" ] } } }, "rejectedPlans" : [ ] }, "ok" : 1 }
हम देख सकते हैं कि इसने IXSCAN
. का उपयोग किया है , जिसका अर्थ है कि उसने अनुक्रमणिका का उपयोग किया है।
जांचें कि क्या इंडेक्स छिपा हुआ है या नहीं
हम getIndexes()
. का उपयोग कर सकते हैं इंडेक्स को छुपाया गया है या नहीं, यह जांचने के लिए विधि फिर से।
db.pets.getIndexes()
परिणाम:
[ { "v" : 2, "key" : { "_id" : 1 }, "name" : "_id_" }, { "v" : 2, "key" : { "name" : 1, "type" : -1 }, "name" : "idx_name_1_type_-1" }, { "v" : 2, "key" : { "weight" : -1 }, "name" : "idx_weight_-1" } ]
हम वही तीन इंडेक्स देखते हैं जो हमने पिछले उदाहरण में देखे थे, लेकिन इस बार हमें "hidden" : true
नहीं दिख रहा है। .
लेकिन हम "hidden" : false
. भी नहीं देखते हैं ।
किसी इंडेक्स को दिखाने से बस "hidden" : true
. हट जाता है getIndexes()
. के परिणाम से भाग . hidden
विकल्प केवल तभी उपलब्ध होता है जब मान true
हो . hidden
विकल्प एक बूलियन मान है, इसलिए हम यह अनुमान लगा सकते हैं कि यदि यह "hidden" : true
नहीं है , तो यह "hidden" : false
. है ।
अनुक्रमणिका छुपा/दिखाई नहीं दे सकते? इस सेटिंग को जांचें।
mongod
featureCompatibilityVersion
कम से कम 4.4
. होना चाहिए इससे पहले कि आप इंडेक्स छुपा सकें। हालांकि, एक बार छुपाए जाने के बाद, एक इंडेक्स featureCompatibilityVersion
. के साथ भी छिपा रहेगा MongoDB 4.4 बायनेरिज़ पर 4.2 पर सेट करें।
आप featureCompatibilityVersion
. की जांच कर सकते हैं निम्नलिखित कोड के साथ सेटिंग:
db.adminCommand(
{
getParameter: 1,
featureCompatibilityVersion: 1
}
)
आप इसे setFeatureCompatibilityVersion
. का उपयोग करके सेट कर सकते हैं आदेश:
db.adminCommand( { setFeatureCompatibilityVersion: "4.4" } )
setFeatureCompatibilityVersion
कमांड को admin
. में चलाने की जरूरत है डेटाबेस।
यह भी ध्यान दें, आप _id
को छुपा नहीं सकते हैं सूचकांक।