MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

कैसे HideIndex () MongoDB में काम करता है

MongoDB ने db.collection.hideIndex() पेश किया मोंगोडीबी 4.4 में विधि।

यह विधि क्वेरी प्लानर से मौजूदा इंडेक्स को छुपाती है। यह आपको वास्तव में इंडेक्स को गिराए बिना किसी इंडेक्स को छोड़ने के संभावित प्रभाव का मूल्यांकन करने की अनुमति देता है।

यदि इसे छुपाने से नकारात्मक प्रभाव पड़ता है, तो आप 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"
	}
]

हम देख सकते हैं कि इसमें तीन इंडेक्स हैं। आइए तीसरा नाम चुनें idx_weight_-1 हमारे उदाहरण के लिए।

सबसे पहले, आइए देखें कि जब हम उस अनुक्रमणिका का उपयोग करने वाली क्वेरी चलाते हैं तो क्वेरी योजना कैसी दिखती है।

db.pets.find( { weight: { $gt: 10 } } ).explain()

यहां, हम ऐसे पालतू जानवरों की तलाश कर रहे हैं जिनका वजन एक निश्चित वजन से अधिक है। हम 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 . का उपयोग करता है जिसका अर्थ है कि यह index.

अब इंडेक्स को छुपाते हैं।

सूचकांक छुपाएं

यह वह जगह है जहां hideIndex() आता है। हम इसका उपयोग इंडेक्स को छिपाने के लिए कर सकते हैं ताकि यह पिछले उदाहरण की तरह क्वेरी प्लान पर दिखाई न दे।

db.pets.hideIndex("idx_weight_-1")

आउटपुट:

{ "hidden_old" : false, "hidden_new" : true, "ok" : 1 }

hideIndex() . का आउटपुट विधि hidden . के लिए पुराना मान प्रदर्शित करती है फ़ील्ड (इस मामले में false ) और नया मान (इस मामले में true )।

हालांकि, अगर हम पहले से छिपी हुई अनुक्रमणिका को छिपाते हैं (या पहले से छिपी हुई अनुक्रमणिका को अनहाइड करते हैं), तो ये प्रदर्शित नहीं होती हैं, और हमें केवल निम्नलिखित मिलते हैं:

{ "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" : "COLLSCAN",
			"filter" : {
				"weight" : {
					"$gt" : 10
				}
			},
			"direction" : "forward"
		},
		"rejectedPlans" : [ ]
	},
	"ok" : 1
}

इस बार हमें एक COLLSCAN मिलता है , जिसका अर्थ है कि उसने अनुक्रमणिका का उपयोग नहीं किया - उसने एक संग्रह स्कैन किया।

जांचें कि कोई अनुक्रमणिका छिपी हुई है या नहीं

आप 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
	}
]

इंडेक्स छुपा नहीं सकते? इस सेटिंग को जांचें।

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 को छुपा नहीं सकते हैं सूचकांक।


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB कैश सिस्टम को समझें

  2. दस्तावेज़ का विशिष्ट भाग प्राप्त करें

  3. संग्रह को छोटा करें

  4. मोंगोडीबी काम नहीं कर रहा है। त्रुटि:dbpath (/data/db) मौजूद नहीं है।

  5. MongoDB लुकअप जब विदेशी क्षेत्र वस्तुओं की एक सरणी है