इंडेक्स बहुत मददगार होते हैं। उनके बिना, MySQL को प्रासंगिक पंक्तियों और स्तंभों को खोजने के लिए पूरी तालिका को स्कैन करना पड़ता है, जो बड़े डेटाबेस में बहुत अक्षम हो सकता है।
यह ट्यूटोरियल इस बात पर ध्यान केंद्रित करेगा कि MySQL में SHOW INDEXES क्लॉज का उपयोग करके इंडेक्स जानकारी को कैसे देखा जाए।
टेबल इंडेक्स दिखाएं
किसी तालिका पर अनुक्रमणिका जानकारी दिखाने के लिए, हम अनुक्रमणिका जानकारी प्राप्त करने के लिए इच्छित तालिका के नाम के बाद SHOW INDEXES खंड का उपयोग करते हैं।
सामान्य वाक्यविन्यास के रूप में दिखाया गया है:
इंडेक्स दिखाएं tbl_name;
उदाहरण के लिए, सकीला नमूना डेटाबेस में एक तालिका पर विचार करें। हम सूचकांक की जानकारी प्राप्त कर सकते हैं जैसा कि नीचे दी गई क्वेरी में दिखाया गया है:
शकीला का उपयोग करें;फिल्म से शो इंडेक्स;
उपरोक्त क्वेरी सकीला डेटाबेस में फिल्म तालिका से अनुक्रमणिका जानकारी प्रदर्शित करेगी। आउटपुट है:
सूचकांक जानकारी को समझना
SHOW INDEXES कमांड निर्दिष्ट तालिका में इंडेक्स के बारे में प्रासंगिक जानकारी प्रदर्शित करता है।
यहां निम्नलिखित शर्तें और उनकी संबंधित जानकारी दी गई है:
- टेबल: यह आउटपुट से पहला कॉलम है। यह उस तालिका का नाम दिखाता है जहां सूचकांक रहता है।
- गैर-अद्वितीय: दूसरा कॉलम दिखाता है कि क्या इंडेक्स में डुप्लिकेट हो सकता है। मान एक बूलियन है, जिसमें 1 इंगित करता है कि सूचकांक में डुप्लिकेट हो सकते हैं और 0 अन्यथा।
- Key_name: तीसरा कॉलम इंडेक्स का नाम दिखाता है। परंपरा के अनुसार, प्राथमिक कुंजी प्राथमिक का सूचकांक नाम लेती है।
- Seq_in_index: चौथा कॉलम 1 के मान से शुरू होने वाले इंडेक्स में कॉलम अनुक्रम संख्या प्रदर्शित करता है।
- आम नाम: पाँचवाँ स्तंभ केवल स्तंभ का नाम है।
- मिलान: छठा कॉलम एक सेक्शन है जो दिखाता है कि इंडेक्स में कॉलम कैसे सॉर्ट किया जाता है। तीन सॉर्टिंग मान हैं, A आरोही क्रम है, B अवरोही क्रम को दर्शाता है, और NULL गैर-क्रमबद्ध है।
- कार्डिनैलिटी: सातवां कॉलम डेटा मान की विशिष्टता को दर्शाता है। इंडेक्स में, यह विशिष्ट इंडेक्स में अद्वितीय मानों की अनुमानित संख्या को दर्शाता है।
- उप_भाग: आठवां कॉलम इंडेक्स उपसर्ग को NULL के साथ प्रदर्शित करता है, यह दर्शाता है कि संपूर्ण कॉलम अनुक्रमित है।
- पैक किया हुआ: नौवां कॉलम दिखाता है कि इंडेक्स कीज़ को कैसे पैक किया जाता है, जिसमें NULL यह दर्शाता है कि कीज़ पैक नहीं हैं।
- शून्य: दसवां कॉलम निर्दिष्ट करता है कि क्या कॉलम में NULL मान हो सकते हैं। हां, यदि कॉलम में शून्य मान हो सकते हैं, और यदि नहीं तो खाली।
- अनुक्रमणिका_प्रकार: ग्यारहवां कॉलम BTREE, HASH, RTREE, और FULLTEXT जैसे इंडेक्स मेथड को दिखाता है।
- टिप्पणी: बारहवां कॉलम एक इंडेक्स के बारे में जानकारी दिखाता है जो उसके कॉलम में वर्णित नहीं है।
- अनुक्रमणिका_टिप्पणी: तेरहवां कॉलम बनाए जाने पर COMMENT विशेषता का उपयोग करके निर्दिष्ट इंडेक्स के बारे में अतिरिक्त जानकारी दिखाता है।
- दृश्यमान: चौदहवाँ कॉलम, हाँ और नहीं के मानों के साथ, क्वेरी ऑप्टिमाइज़र को दिखाई देने वाला सूचकांक है।
- अभिव्यक्ति: पंद्रहवां स्तंभ प्रदर्शित करता है कि क्या अनुक्रमणिका किसी व्यंजक का उपयोग करती है न कि स्तंभ या स्तंभ उपसर्ग मान का।
सुझाव: SHOW INDEXES क्वेरी से इंडेक्स के बारे में जानकारी SQLStatistics के समान है।
स्कीमा इंडेक्स दिखाएं
आप किसी स्कीमा के बारे में अनुक्रमणिका जानकारी भी प्राप्त कर सकते हैं। इस परिणाम को प्राप्त करने के लिए सामान्य सिंटैक्स नीचे दिया गया है:
INFORMATION_SCHEMA से तालिका_नाम, अनुक्रमणिका_नाम चुनें। सांख्यिकी जहां TABLE_SCHEMA = schema_name;नीचे दी गई क्वेरी पर विचार करें जो सकीला स्कीमा के बारे में जानकारी दिखाती है:
चयन तालिका_नाम, अनुक्रमणिका_नाम info_schema.statistics से जहां table_schema ='सकिला';यह सकीला स्कीमा में अनुक्रमित के बारे में जानकारी प्रदर्शित करेगा जैसा कि नीचे दिए गए आउटपुट में दिखाया गया है:
+ --------------- + ----------------------------- +|तालिका नाम|INDEX_NAME|
+ --------------- + ----------------------------- +
|अभिनेता|मुख्य|
|अभिनेता|idx_actor_last_name|
|पता|मुख्य|
|पता|idx_fk_city_id|
|पता|idx_स्थान|
|श्रेणी|मुख्य|
|शहर|मुख्य|
|शहर|idx_fk_country_id|
|देश|मुख्य|
|ग्राहक|मुख्य|
|ग्राहक|idx_fk_store_id|
|ग्राहक|idx_fk_address_id|
|ग्राहक|idx_last_name|
|फ़िल्म|मुख्य|
|फ़िल्म|आईडीएक्स_शीर्षक|
|फ़िल्म|idx_fk_language_id|
|फ़िल्म|आईडीएक्स_एफके_ओरिजिनल_भाषा_आईडी|
|फिल्म अभिनेता|मुख्य|
|फिल्म अभिनेता|मुख्य|
|फिल्म अभिनेता|idx_fk_film_id|
|फिल्म_श्रेणी|मुख्य|
|फिल्म_श्रेणी|मुख्य|
|फिल्म_श्रेणी|fk_film_category_category|
|फिल्म_पाठ|मुख्य|
|फिल्म_पाठ|idx_title_description|
|फिल्म_पाठ|idx_title_description|
|सूची|मुख्य|
|सूची|idx_fk_film_id|
|सूची|idx_store_id_film_id|
|सूची|idx_store_id_film_id|
|----------------------------- आउटपुट काटा गया--------------------- --------
आप नीचे दिखाए गए प्रश्न का उपयोग करके सर्वर में सभी स्कीमाओं से भी जानकारी प्राप्त कर सकते हैं:
तालिका_नाम, अनुक्रमणिका_नाम का चयन info_schema.statistics से करें;ध्यान दें : उपरोक्त क्वेरी बहुत सारी जानकारी डंप करती है। शायद ही आपको सभी स्कीमा से इंडेक्स प्राप्त करने की आवश्यकता होगी। हालांकि, एक नमूना आउटपुट नीचे है:
+ ------------------------ + ------------- +|तालिका नाम|INDEX_NAME|
+ ------------------------ + ------------- +
|innodb_table_stats|मुख्य|
|innodb_table_stats|मुख्य|
|innodb_index_stats|मुख्य|
|innodb_index_stats|मुख्य|
|innodb_index_stats|मुख्य|
+ ------------------------ + ------------- +
निष्कर्ष
इस ट्यूटोरियल में, हमने चर्चा की कि तालिका में इंडेक्स के बारे में जानकारी प्राप्त करने के लिए MySQL SHOW INDEXES क्वेरी का उपयोग कैसे करें। हमने MySQL सर्वर में एक या सभी स्कीमा से इंडेक्स के बारे में जानकारी प्राप्त करने के लिए info_schema का उपयोग करने पर भी ध्यान दिया।