MySQL या स्कीमा में सभी इंडेक्स कैसे दिखाएं?

How Show All Indexes Mysql



MySQL डेटाबेस इंडेक्स एक प्रकार की डेटा संरचना को संदर्भित करता है जिसका उपयोग डेटाबेस में डेटा संगठन के रूप में किया जाता है और MySQL में किए गए विभिन्न कार्यों की गति को आगे बढ़ाने में मदद करता है।

इंडेक्स बहुत मददगार होते हैं। उनके बिना, MySQL को प्रासंगिक पंक्तियों और स्तंभों को खोजने के लिए पूरी तालिका को स्कैन करना पड़ता है, जो बड़े डेटाबेस में बहुत अक्षम हो सकता है।







यह ट्यूटोरियल इस बात पर ध्यान केंद्रित करेगा कि MySQL में SHOW INDEXES क्लॉज का उपयोग करके इंडेक्स जानकारी को कैसे देखा जाए।



टेबल इंडेक्स दिखाएं

किसी तालिका पर अनुक्रमणिका जानकारी दिखाने के लिए, हम अनुक्रमणिका जानकारी प्राप्त करने के लिए इच्छित तालिका के नाम के बाद SHOW INDEXES खंड का उपयोग करते हैं।



सामान्य वाक्यविन्यास के रूप में दिखाया गया है:





इंडेक्स दिखाएं tbl_name;

उदाहरण के लिए, सकीला नमूना डेटाबेस में एक तालिका पर विचार करें। हम सूचकांक की जानकारी प्राप्त कर सकते हैं जैसा कि नीचे दी गई क्वेरी में दिखाया गया है:

शकीला का उपयोग करें;

फिल्म से शो इंडेक्स;

उपरोक्त क्वेरी सकीला डेटाबेस में फिल्म तालिका से अनुक्रमणिका जानकारी प्रदर्शित करेगी। आउटपुट है:



सूचकांक जानकारी को समझना

SHOW INDEXES कमांड निर्दिष्ट तालिका में इंडेक्स के बारे में प्रासंगिक जानकारी प्रदर्शित करता है।

यहां निम्नलिखित शर्तें और उनकी संबंधित जानकारी दी गई है:

  1. टेबल: यह आउटपुट से पहला कॉलम है। यह उस तालिका का नाम दिखाता है जहां सूचकांक रहता है।
  2. गैर-अद्वितीय: दूसरा कॉलम दिखाता है कि क्या इंडेक्स में डुप्लिकेट हो सकता है। मान एक बूलियन है, जिसमें 1 इंगित करता है कि सूचकांक में डुप्लिकेट हो सकते हैं और 0 अन्यथा।
  3. Key_name: तीसरा कॉलम इंडेक्स का नाम दिखाता है। परंपरा के अनुसार, प्राथमिक कुंजी प्राथमिक का सूचकांक नाम लेती है।
  4. Seq_in_index: चौथा कॉलम 1 के मान से शुरू होने वाले इंडेक्स में कॉलम अनुक्रम संख्या प्रदर्शित करता है।
  5. आम नाम: पाँचवाँ स्तंभ केवल स्तंभ का नाम है।
  6. मिलान: छठा कॉलम एक सेक्शन है जो दिखाता है कि इंडेक्स में कॉलम कैसे सॉर्ट किया जाता है। तीन सॉर्टिंग मान हैं, A आरोही क्रम है, B अवरोही क्रम को दर्शाता है, और NULL गैर-क्रमबद्ध है।
  7. कार्डिनैलिटी: सातवां कॉलम डेटा मान की विशिष्टता को दर्शाता है। इंडेक्स में, यह विशिष्ट इंडेक्स में अद्वितीय मानों की अनुमानित संख्या को दर्शाता है।
  8. उप_भाग: आठवां कॉलम इंडेक्स उपसर्ग को NULL के साथ प्रदर्शित करता है, यह दर्शाता है कि संपूर्ण कॉलम अनुक्रमित है।
  9. पैक किया हुआ: नौवां कॉलम दिखाता है कि इंडेक्स कीज़ को कैसे पैक किया जाता है, जिसमें NULL यह दर्शाता है कि कीज़ पैक नहीं हैं।
  10. शून्य: दसवां कॉलम निर्दिष्ट करता है कि क्या कॉलम में NULL मान हो सकते हैं। हां, यदि कॉलम में शून्य मान हो सकते हैं, और यदि नहीं तो खाली।
  11. अनुक्रमणिका_प्रकार: ग्यारहवां कॉलम BTREE, HASH, RTREE, और FULLTEXT जैसे इंडेक्स मेथड को दिखाता है।
  12. टिप्पणी: बारहवां कॉलम एक इंडेक्स के बारे में जानकारी दिखाता है जो उसके कॉलम में वर्णित नहीं है।
  13. अनुक्रमणिका_टिप्पणी: तेरहवां कॉलम बनाए जाने पर COMMENT विशेषता का उपयोग करके निर्दिष्ट इंडेक्स के बारे में अतिरिक्त जानकारी दिखाता है।
  14. दृश्यमान: चौदहवाँ कॉलम, हाँ और नहीं के मानों के साथ, क्वेरी ऑप्टिमाइज़र को दिखाई देने वाला सूचकांक है।
  15. अभिव्यक्ति: पंद्रहवां स्तंभ प्रदर्शित करता है कि क्या अनुक्रमणिका किसी व्यंजक का उपयोग करती है न कि स्तंभ या स्तंभ उपसर्ग मान का।

सुझाव: 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 का उपयोग करने पर भी ध्यान दिया।