DBMS - अनुक्रमण
हम जानते हैं कि डेटा को रिकॉर्ड के रूप में संग्रहीत किया जाता है। हर रिकॉर्ड में एक महत्वपूर्ण क्षेत्र होता है, जो इसे विशिष्ट रूप से पहचानने में मदद करता है।
इंडेक्सिंग एक डेटा संरचना तकनीक है जो कुछ विशेषताओं के आधार पर डेटाबेस फ़ाइलों से रिकॉर्ड को कुशलतापूर्वक प्राप्त करने के लिए है, जिस पर इंडेक्सिंग की गई है। डेटाबेस सिस्टम में इंडेक्सिंग जैसा हम किताबों में देखते हैं वैसा ही है।
अनुक्रमण को इसकी अनुक्रमण विशेषताओं के आधार पर परिभाषित किया गया है। अनुक्रमण निम्न प्रकार के हो सकते हैं -
Primary Index- प्राथमिक सूचकांक एक आदेशित डेटा फ़ाइल पर परिभाषित किया गया है। डेटा फ़ाइल एक पर आदेश दिया हैkey field। मुख्य क्षेत्र आमतौर पर संबंध की प्राथमिक कुंजी है।
Secondary Index - द्वितीयक सूचकांक एक क्षेत्र से उत्पन्न किया जा सकता है जो एक उम्मीदवार कुंजी है और हर रिकॉर्ड में एक अद्वितीय मूल्य है, या डुप्लिकेट मानों के साथ एक गैर-कुंजी है।
Clustering Index- क्लस्टरिंग इंडेक्स एक ऑर्डर की गई डेटा फ़ाइल पर परिभाषित किया गया है। डेटा फ़ाइल एक गैर-कुंजी फ़ील्ड पर ऑर्डर की जाती है।
क्रमबद्ध अनुक्रमण दो प्रकार का होता है -
- घना सूचकांक
- विरल सूचकांक
घना सूचकांक
घने सूचकांक में, डेटाबेस में प्रत्येक खोज कुंजी मान के लिए एक सूचकांक रिकॉर्ड होता है। यह तेजी से खोज करता है, लेकिन इंडेक्स रिकॉर्ड को स्टोर करने के लिए अधिक स्थान की आवश्यकता होती है। इंडेक्स रिकॉर्ड में डिस्क पर वास्तविक रिकॉर्ड के लिए खोज कुंजी मान और एक सूचक होता है।
विरल सूचकांक
विरल सूचकांक में, प्रत्येक खोज कुंजी के लिए सूचकांक रिकॉर्ड नहीं बनाए जाते हैं। यहां एक इंडेक्स रिकॉर्ड में डिस्क पर डेटा के लिए एक खोज कुंजी और एक वास्तविक सूचक होता है। किसी रिकॉर्ड को खोजने के लिए, हम सबसे पहले इंडेक्स रिकॉर्ड के आधार पर आगे बढ़ते हैं और डेटा के वास्तविक स्थान पर पहुंचते हैं। यदि हम जिस डेटा की तलाश कर रहे हैं वह वह नहीं है जहां हम सीधे सूचकांक का अनुसरण करके पहुंचते हैं, तो सिस्टम तब तक अनुक्रमिक खोज शुरू करता है जब तक वांछित डेटा नहीं मिलता है।
बहुस्तरीय सूचकांक
इंडेक्स रिकॉर्ड में खोज-कुंजी मान और डेटा पॉइंटर्स शामिल हैं। मल्टीलेवल इंडेक्स डिस्क पर वास्तविक डेटाबेस फ़ाइलों के साथ संग्रहीत किया जाता है। जैसे-जैसे डेटाबेस का आकार बढ़ता है, वैसे-वैसे सूचकांकों का आकार बढ़ता जाता है। सूचकांक रिकॉर्ड को मुख्य मेमोरी में रखने की अत्यधिक आवश्यकता है ताकि तलाशी अभियान को तेज किया जा सके। यदि सिंगल-लेवल इंडेक्स का उपयोग किया जाता है, तो बड़े आकार के इंडेक्स को मेमोरी में नहीं रखा जा सकता है जो कई डिस्क एक्सेस तक ले जाता है।
मल्टी-लेवल इंडेक्स सबसे छोटे स्तर को बनाने के लिए इंडेक्स को कई छोटे सूचकांकों में तोड़ने में मदद करता है ताकि इसे एक सिंगल डिस्क ब्लॉक में बचाया जा सके, जिसे आसानी से मुख्य मेमोरी में कहीं भी समायोजित किया जा सकता है।
ब + वृक्ष
AB + ट्री एक संतुलित बाइनरी सर्च ट्री है जो मल्टी-लेवल इंडेक्स फॉर्मेट का अनुसरण करता है। B + ट्री का लीफ नोड वास्तविक डेटा पॉइंटर्स दर्शाता है। बी + पेड़ सुनिश्चित करता है कि सभी पत्ती नोड्स एक ही ऊंचाई पर रहें, इस प्रकार संतुलित। इसके अतिरिक्त, पत्ती नोड्स एक लिंक सूची का उपयोग करके जुड़े हुए हैं; इसलिए, एक B + वृक्ष यादृच्छिक पहुँच के साथ-साथ अनुक्रमिक पहुँच का समर्थन कर सकता है।
बी + ट्री की संरचना
प्रत्येक पत्ती नोड मूल नोड से समान दूरी पर है। एबी + वृक्ष क्रम का हैn कहाँ पे nहर बी + पेड़ के लिए तय है ।
Internal nodes -
- रूट नोड को छोड़कर आंतरिक (गैर-पत्ती) नोड्स में कम से कम ⌉n / 2ers पॉइंटर्स होते हैं।
- अधिक से अधिक, एक आंतरिक नोड में हो सकता है n संकेत दिए गए।
Leaf nodes -
- लीफ नोड्स में कम से कम /n / 2odes रिकॉर्ड पॉइंटर्स और ⌉n / 2 values प्रमुख मान होते हैं।
- अधिकतम पर, एक पत्ती नोड शामिल हो सकता है n रिकॉर्ड संकेत और n प्रमुख मूल्य।
- प्रत्येक पत्ती के नोड में एक ब्लॉक पॉइंटर होता है P अगले पत्ते नोड को इंगित करने के लिए और एक लिंक की गई सूची बनाता है।
बी + ट्री सम्मिलन
बी + पेड़ नीचे से भरे हुए हैं और प्रत्येक प्रविष्टि पत्ती नोड पर की जाती है।
- यदि एक पत्ती नोड ओवरफ्लो होता है -
नोड को दो भागों में विभाजित करें।
पर विभाजन i = ⌊(m+1)/2⌋.
प्रथम i प्रविष्टियों को एक नोड में संग्रहीत किया जाता है।
शेष प्रविष्टियाँ (i + 1 बाद में) एक नए नोड में स्थानांतरित हो गई हैं।
ith कुंजी पत्ता के माता-पिता पर दोहराई गई है।
यदि एक गैर-पत्ती नोड अधिकता है -
नोड को दो भागों में विभाजित करें।
नोड पर विभाजन i = ⌈(m+1)/2⌉।
तक प्रविष्ट करता है i एक नोड में रखे जाते हैं।
शेष प्रविष्टियों को एक नए नोड में स्थानांतरित कर दिया गया है।
बी + ट्री विलोपन
पत्ती नोड्स पर बी + ट्री प्रविष्टियां हटा दी जाती हैं।
लक्ष्य प्रविष्टि को खोजा और हटा दिया गया है।
यदि यह एक आंतरिक नोड है, तो बाईं स्थिति से प्रविष्टि के साथ हटाएं और बदलें।
हटाने के बाद, अंडरफ्लो का परीक्षण किया जाता है,
यदि अंडरफ़्लो होता है, तो उसके द्वारा छोड़े गए नोड्स से प्रविष्टियों को वितरित करें।
यदि वितरण बाएं से संभव नहीं है, तो
इसके लिए नोड्स से वितरित करें।
यदि वितरण बाएं या दाएं से संभव नहीं है, तो
नोड को बाएँ और दाएँ के साथ मर्ज करें।