HSQLDB - अनुक्रमित
ए database indexएक डेटा संरचना है जो एक तालिका में संचालन की गति में सुधार करती है। एक या एक से अधिक स्तंभों का उपयोग करके इंडेक्स बनाए जा सकते हैं, जो तेजी से रैंडम लुकअप और रिकॉर्ड तक पहुंच के कुशल आदेश दोनों के लिए आधार प्रदान करते हैं।
एक इंडेक्स बनाते समय, यह विचार किया जाना चाहिए कि एसक्यूएल प्रश्न बनाने के लिए कौन से कॉलम का उपयोग किया जाएगा, और उन कॉलमों पर एक या अधिक इंडेक्स बनाएं।
व्यावहारिक रूप से, इंडेक्स भी एक प्रकार की टेबल होती हैं, जो प्राइमरी की या इंडेक्स फील्ड और एक पॉइंटर को प्रत्येक टेबल को वास्तविक टेबल में रखती हैं।
उपयोगकर्ता अनुक्रमित नहीं देख सकते हैं। उनका उपयोग केवल प्रश्नों को गति देने के लिए किया जाता है और डेटाबेस खोज इंजन द्वारा रिकॉर्ड को जल्दी से खोजने के लिए उपयोग किया जाएगा।
INSERT और UPDATE स्टेटमेंट में टेबल्स इंडेक्स होने में अधिक समय लगता है, जबकि SELECT स्टेटमेंट उन टेबलों पर तेजी से चलते हैं। सम्मिलित करते समय या अपडेट करते समय, डेटाबेस को इंडेक्स मानों को भी सम्मिलित या अपडेट करने की आवश्यकता होती है।
सरल और अनोखा सूचकांक
आप एक तालिका पर एक अद्वितीय सूचकांक बना सकते हैं। एunique indexइसका मतलब है कि दो पंक्तियों में समान सूचकांक मान नहीं हो सकता है। तालिका पर एक इंडेक्स बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE UNIQUE INDEX index_name
ON table_name (column1, column2,...);
इंडेक्स बनाने के लिए आप एक या अधिक कॉलम का उपयोग कर सकते हैं। उदाहरण के लिए, tutorial_author का उपयोग करके tutorial_tbl पर एक इंडेक्स बनाएं।
CREATE UNIQUE INDEX AUTHOR_INDEX
ON tutorials_tbl (tutorial_author)
आप एक मेज पर एक साधारण सूचकांक बना सकते हैं। सरल इंडेक्स बनाने के लिए क्वेरी से केवल UNIQUE कीवर्ड को छोड़ दें। एsimple index एक तालिका में डुप्लिकेट मानों की अनुमति देता है।
यदि आप किसी कॉलम में मानों को एक अवरोही क्रम में अनुक्रमित करना चाहते हैं, तो आप कॉलम नाम के बाद आरक्षित शब्द DESC जोड़ सकते हैं।
CREATE UNIQUE INDEX AUTHOR_INDEX
ON tutorials_tbl (tutorial_author DESC)
जोड़ने और ड्रॉप INDEX करने के लिए आदेश
तालिका में अनुक्रमणिका जोड़ने के लिए चार प्रकार के कथन हैं -
ALTER TABLE tbl_name ADD PRIMARY KEY (column_list) - यह कथन एक प्राथमिक कुंजी जोड़ता है, जिसका अर्थ है कि अनुक्रमित मान अद्वितीय होना चाहिए और NULL नहीं हो सकता।
ALTER TABLE tbl_name ADD UNIQUE index_name (column_list) - यह कथन एक इंडेक्स बनाता है जिसके लिए मान अद्वितीय होने चाहिए (NULL मान के अपवाद के साथ, जो कई बार दिखाई दे सकते हैं)।
ALTER TABLE tbl_name ADD INDEX index_name (column_list) - यह एक साधारण सूचकांक जोड़ता है जिसमें कोई भी मूल्य एक से अधिक बार दिखाई दे सकता है।
ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list) - यह एक विशेष FULLTEXT इंडेक्स बनाता है जो टेक्स्ट-सर्चिंग उद्देश्यों के लिए उपयोग किया जाता है।
मौजूदा तालिका में अनुक्रमणिका जोड़ने के लिए निम्नलिखित प्रश्न है।
ALTER TABLE testalter_tbl ADD INDEX (c);
आप ALTER कमांड के साथ DROP क्लॉज का उपयोग करके किसी भी INDEX को गिरा सकते हैं। उपर्युक्त सूचकांक को छोड़ने के लिए निम्नलिखित क्वेरी है।
ALTER TABLE testalter_tbl DROP INDEX (c);
INDEX सूचना प्रदर्शित करना
टेबल से जुड़े सभी इंडेक्स को सूचीबद्ध करने के लिए आप SHOW INDEX कमांड का उपयोग कर सकते हैं। वर्टिकल-फॉर्मेट आउटपुट (\ G द्वारा निर्दिष्ट) अक्सर इस कथन के साथ उपयोगी होता है, ताकि लंबी लाइन रैपराउंड से बचा जा सके।
तालिका के बारे में सूचकांक जानकारी प्रदर्शित करने के लिए जेनेरिक सिंटैक्स निम्नलिखित है।
SHOW INDEX FROM table_name\G