एक इंडेक्स, क्लस्टर्ड या नॉन-क्लस्टर, का उपयोग क्वेरी ऑप्टिमाइज़र द्वारा किया जा सकता है यदि और केवल तभी जब इंडेक्स में सबसे बाईं कुंजी को फ़िल्टर किया जाता है। इसलिए यदि आप कॉलम (ए, बी, सी) पर एक इंडेक्स परिभाषित करते हैं, तो [email protected]
पर WHERE की स्थिति , [email protected]
. पर या [email protected] AND [email protected]
. पर पूरी तरह से सूचकांक का लाभ नहीं उठाएगा (नोट देखें)। यह शर्तों में शामिल होने पर भी लागू होता है। कोई भी WHERE फ़िल्टर जिसमें A
. शामिल है सूचकांक पर विचार करेगा:[email protected]
या [email protected] AND [email protected]
या [email protected] AND [email protected]
या [email protected] AND [email protected] AND [email protected]
.
तो आपके उदाहरण में यदि आप part_no
. पर संकुल अनुक्रमणिका बनाते हैं बाईं ओर की कुंजी के रूप में, फिर एक विशिष्ट part_id
. की तलाश में एक क्वेरी होगा नहीं अनुक्रमणिका का उपयोग करें और part-id
. पर एक अलग गैर-संकुल अनुक्रमणिका मौजूद होनी चाहिए ।
अब इस सवाल के बारे में कि क्लस्टर किए गए . कितने इंडेक्स में से कौन सा होना चाहिए? एक। यदि आपके पास कई क्वेरी पैटर्न हैं जो समान महत्व और आवृत्ति के बारे में हैं और आवश्यक कुंजियों के संदर्भ में एक-दूसरे का खंडन करते हैं (उदाहरण के लिए या तो द्वारा लगातार क्वेरीज़ part_no
या part_id
) तो आप अन्य कारकों को ध्यान में रखते हैं:
- चौड़ाई :संकुल अनुक्रमणिका कुंजी का उपयोग सभी . द्वारा लुकअप कुंजी के रूप में किया जाता है अन्य गैर-संकुल सूचकांक। इसलिए यदि आप एक विस्तृत कुंजी चुनते हैं (दो यूनीकिडेंटिफायर कॉलम कहें) तो आप अन्य सभी इंडेक्स को व्यापक बना रहे हैं, इस प्रकार अधिक जगह ले रहे हैं, अधिक आईओ उत्पन्न कर रहे हैं और सबकुछ धीमा कर रहे हैं। इसलिए पढ़ने के दृष्टिकोण से समान रूप से अच्छी कुंजियों के बीच, क्लस्टर के रूप में सबसे संकरी कुंजी चुनें और व्यापक वाली को गैर-क्लस्टर बनाएं।
- विवाद :यदि आपके पास डालने और हटाने के विशिष्ट पैटर्न हैं, तो उन्हें भौतिक रूप से अलग करने का प्रयास करें ताकि वे संकुल सूचकांक के विभिन्न भागों पर हों। उदा. यदि तालिका एक तार्किक छोर पर सभी प्रविष्टियों के साथ एक कतार के रूप में कार्य करती है और अन्य तार्किक छोर पर सभी हटा दी जाती है, तो क्लस्टर किए गए अनुक्रमणिका को लेआउट करने का प्रयास करें ताकि भौतिक क्रम इस तार्किक क्रम से मेल खा सके (उदाहरण के लिए एनक्यू ऑर्डर)।
- विभाजन करना :यदि तालिका बहुत बड़ी है और आप विभाजन को परिनियोजित करने की योजना बना रहे हैं तो विभाजन कुंजी संकुल अनुक्रमणिका होनी चाहिए। विशिष्ट उदाहरण ऐतिहासिक डेटा है जिसे एक स्लाइडिंग विंडो विभाजन योजना का उपयोग करके संग्रहीत किया जाता है। भले ही संस्थाओं के पास 'entity_id' जैसी तार्किक प्राथमिक कुंजी हो, क्लस्टर इंडेक्स डेटाटाइम कॉलम द्वारा किया जाता है जिसका उपयोग विभाजन समारोह के लिए भी किया जाता है।
- स्थिरता :एक कुंजी जो अक्सर बदलती है वह क्लस्टर कुंजी के लिए एक खराब उम्मीदवार है क्योंकि प्रत्येक क्लस्टर कुंजी मान को अपडेट करता है और सभी को बाध्य करता है गैर-संकुल अनुक्रमणिका उनके द्वारा संग्रहीत लुकअप कुंजी को अद्यतन करने के लिए। एक संकुल कुंजी के अद्यतन के रूप में रिकॉर्ड को एक अलग पृष्ठ में स्थानांतरित करने की भी संभावना है, यह संकुल अनुक्रमणिका पर विखंडन का कारण बन सकता है।
नोट:नहीं पूरी तरह लीवरेज क्योंकि कभी-कभी इंजन स्कैन . के लिए एक गैर-संकुल सूचकांक का चयन करेगा संकुल सूचकांक के बजाय केवल इसलिए कि संकरा है और इस प्रकार स्कैन करने के लिए कम पृष्ठ हैं। मेरे उदाहरण में यदि आपके पास [email protected]
पर एक अनुक्रमणिका (A, B, C) और WHERE फ़िल्टर है और क्वेरी प्रोजेक्ट C
, अनुक्रमणिका का उपयोग होने की संभावना है, लेकिन खोज के रूप में नहीं, स्कैन के रूप में, क्योंकि अभी भी एक पूर्ण क्लस्टर स्कैन (कम पृष्ठ) की तुलना में तेज़ है।