PostgreSQL - INDEXES
अनुक्रमित विशेष लुकअप टेबल हैं जो डेटाबेस खोज इंजन डेटा पुनर्प्राप्ति को गति देने के लिए उपयोग कर सकते हैं। सीधे शब्दों में कहें, एक सूचकांक एक तालिका में डेटा के लिए एक सूचक है। एक डेटाबेस में एक इंडेक्स एक किताब के पीछे एक इंडेक्स के समान है।
उदाहरण के लिए, यदि आप किसी निश्चित विषय पर चर्चा करने वाली पुस्तक के सभी पृष्ठों को संदर्भित करना चाहते हैं, तो आपको पहले सूचकांक का उल्लेख करना होगा, जो सभी विषयों को वर्णानुक्रम में सूचीबद्ध करता है और फिर एक या अधिक विशिष्ट पृष्ठ संख्याओं को संदर्भित करता है।
एक इंडेक्स सेलेक्टेड क्वेश्चन को गति देने में मदद करता है और जहां क्लॉस होता है; हालाँकि, यह डेटा इनपुट को धीमा करता है, UPDATE और INSERT के साथ। इंडेक्स डेटा पर कोई प्रभाव नहीं बनाया या गिराया जा सकता है।
एक इंडेक्स बनाने में क्रिएट इंडेक्स स्टेटमेंट शामिल होता है, जो आपको इंडेक्स नाम देने की अनुमति देता है, तालिका को निर्दिष्ट करने के लिए और कौन सा कॉलम या कॉलम इंडेक्स करने के लिए, और यह इंगित करने के लिए कि इंडेक्स आरोही या अवरोही क्रम में है या नहीं।
सूचकांक अद्वितीय भी हो सकता है, UNIQUE बाधा के समान, इसमें सूचकांक कॉलम में डुप्लिकेट प्रविष्टियों या स्तंभों के संयोजन को रोकता है जिस पर एक सूचकांक है।
क्रिएट इंडेक्स कमांड
का मूल सिंटैक्स CREATE INDEX इस प्रकार है -
CREATE INDEX index_name ON table_name;
सूचकांक प्रकार
PostgreSQL कई सूचकांक प्रकार प्रदान करता है: बी-ट्री, हैश, जीएसटी, एसपी-जीएसटी और जीआईएन। प्रत्येक सूचकांक प्रकार एक अलग एल्गोरिथ्म का उपयोग करता है जो विभिन्न प्रकार के प्रश्नों के लिए सबसे उपयुक्त है। डिफ़ॉल्ट रूप से, क्रिएट इंडेक्स कमांड बी-ट्री इंडेक्स बनाता है, जो सबसे आम स्थितियों में फिट होता है।
एकल-स्तंभ अनुक्रमणिका
एकल-स्तंभ अनुक्रमणिका वह है जो केवल एक तालिका स्तंभ के आधार पर बनाई गई है। मूल वाक्य रचना इस प्रकार है -
CREATE INDEX index_name
ON table_name (column_name);
बहुरंगी अनुक्रमणिका
एक टेबल के एक से अधिक स्तंभों पर एक बहुरंगी सूचकांक को परिभाषित किया गया है। मूल वाक्य रचना इस प्रकार है -
CREATE INDEX index_name
ON table_name (column1_name, column2_name);
एकल-स्तंभ अनुक्रमणिका या बहुरंगी अनुक्रमणिका बनाने के लिए, स्तंभ (s) को ध्यान में रखें जिसे आप फ़िल्टर शर्तों के रूप में क्वेरी के WHERE खंड में बहुत बार उपयोग कर सकते हैं।
क्या केवल एक कॉलम का उपयोग किया जाना चाहिए, एकल-कॉलम इंडेक्स का विकल्प होना चाहिए। क्या दो या दो से अधिक कॉलम होने चाहिए, जिन्हें अक्सर फिल्टर के रूप में WHERE क्लॉज में उपयोग किया जाता है, बहुरंगी सूचकांक सबसे अच्छा विकल्प होगा।
अनोखा सूचकांक
यूनीक इंडेक्स का उपयोग न केवल प्रदर्शन के लिए किया जाता है, बल्कि डेटा अखंडता के लिए भी किया जाता है। एक अद्वितीय सूचकांक किसी भी डुप्लिकेट मानों को तालिका में सम्मिलित करने की अनुमति नहीं देता है। मूल वाक्य रचना इस प्रकार है -
CREATE UNIQUE INDEX index_name
on table_name (column_name);
आंशिक सूचकांक
एक आंशिक सूचकांक एक तालिका के सबसेट पर निर्मित एक सूचकांक है; सबसेट को एक सशर्त अभिव्यक्ति (आंशिक सूचकांक की विधेय कहा जाता है) द्वारा परिभाषित किया गया है। अनुक्रमणिका में केवल उन तालिका पंक्तियों के लिए प्रविष्टियाँ होती हैं जो विधेय को संतुष्ट करती हैं। मूल वाक्य रचना इस प्रकार है -
CREATE INDEX index_name
on table_name (conditional_expression);
निहित सूचकांक
इंप्लिकेट इंडेक्स इंडेक्स होते हैं जो किसी ऑब्जेक्ट के बनने पर डेटाबेस सर्वर द्वारा स्वचालित रूप से बनाए जाते हैं। प्राथमिक प्रमुख बाधाओं और अद्वितीय बाधाओं के लिए इंडेक्स स्वचालित रूप से बनाए जाते हैं।
उदाहरण
निम्नलिखित एक उदाहरण है जहां हम वेतन स्तंभ के लिए कंपनी तालिका पर एक सूचकांक बनाएंगे -
# CREATE INDEX salary_index ON COMPANY (salary);
अब, कंपनी तालिका पर उपलब्ध सभी सूचकांकों का उपयोग करते हुए सूची दें \d company आदेश।
# \d company
यह निम्नलिखित परिणाम का उत्पादन करेगा, जहां company_pkey एक अंतर्निहित सूचकांक है, जो तालिका बनाते समय बनाया गया था।
Table "public.company"
Column | Type | Modifiers
---------+---------------+-----------
id | integer | not null
name | text | not null
age | integer | not null
address | character(50) |
salary | real |
Indexes:
"company_pkey" PRIMARY KEY, btree (id)
"salary_index" btree (salary)
आप संपूर्ण इंडेक्स डेटाबेस को नीचे सूचीबद्ध कर सकते हैं \di कमांड -
DROP INDEX कमांड
PostgreSQL का उपयोग करके एक इंडेक्स को गिराया जा सकता है DROPआदेश। इंडेक्स ड्रॉप करते समय ध्यान रखा जाना चाहिए क्योंकि प्रदर्शन धीमा या बेहतर हो सकता है।
मूल वाक्य रचना इस प्रकार है -
DROP INDEX index_name;
पूर्व में बनाए गए इंडेक्स को हटाने के लिए आप निम्न कथन का उपयोग कर सकते हैं -
# DROP INDEX salary_index;
जब अनुक्रमित से बचा जाना चाहिए?
हालांकि अनुक्रमित एक डेटाबेस के प्रदर्शन को बढ़ाने के इरादे से किए जाते हैं, लेकिन कई बार ऐसे समय होते हैं जब उन्हें टाला जाना चाहिए। सूचकांक के उपयोग पर पुनर्विचार किया जाना चाहिए, जब निम्नलिखित दिशा-निर्देश इंगित करते हैं -
इंडेक्स का उपयोग छोटी तालिकाओं पर नहीं किया जाना चाहिए।
टेबल्स जिनमें बार-बार, बड़े बैच अपडेट होते हैं या ऑपरेशन सम्मिलित होते हैं।
उन स्तंभों पर अनुक्रमणिका का उपयोग नहीं किया जाना चाहिए जिनमें अधिक संख्या में NULL मान हैं।
जिन कॉलमों में अक्सर हेरफेर किया जाता है, उन्हें अनुक्रमित नहीं किया जाना चाहिए।