MySQL में इंजन द्वारा टेबल दिखाएं


84

मैं किसी दिए गए इंजन, जैसे InnoDB, MyISAM, FEDERATED के साथ MySQL में सभी तालिकाओं को कैसे दिखाऊँगा?

जवाबों:


130

उपयोग INFORMATION_SCHEMA.TABLESतालिका:

SELECT table_name FROM INFORMATION_SCHEMA.TABLES
  WHERE engine = 'InnoDB'

4
आप इसके साथ स्कीमा भी चाहते हैं, इसलिए क्वेरी इस तरह दिखाई देगी: SELECT TABLE_SCHEMA, TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE इंजन = 'InnoDB'
डैन बॉलिंग

81

यदि आप एकल डेटाबेस से परिणाम चाहते हैं

SELECT TABLE_NAME FROM information_schema.TABLES
    WHERE TABLE_SCHEMA = 'dbname' AND engine = 'InnoDB';

1
मैंने इसे इसलिए चिन्हित किया क्योंकि आप शायद केवल एक निश्चित स्कीमा देखना चाहते हैं
Csaba Toth

6

अन्य उदाहरण यहाँ।

इंजन द्वारा सभी टेबल (सिस्टम टेबल को छोड़कर):

SELECT TABLE_SCHEMA as DbName ,TABLE_NAME as TableName ,ENGINE as Engine 
FROM information_schema.TABLES 
WHERE ENGINE = 'MyISAM' -- or InnoDB or whatever
AND TABLE_SCHEMA NOT IN('mysql','information_schema','performance_schema');

इंजन को छोड़कर सभी टेबल (सिस्टम टेबल को छोड़कर):

SELECT TABLE_SCHEMA as DbName ,TABLE_NAME as TableName ,ENGINE as Engine 
FROM information_schema.TABLES 
WHERE ENGINE != 'MyISAM' -- or InnoDB or whatever
AND TABLE_SCHEMA NOT IN('mysql','information_schema','performance_schema');

1

अगर कुछ में समस्या है और देखना चाहते हैं कि डीबी विशिष्ट इंजन के साथ तालिकाओं में है

SELECT 
        (SELECT group_concat(TABLE_NAME) 
            FROM information_schema.TABLES
            WHERE TABLE_SCHEMA = 'database1' 
            AND engine = 'MyIsam'
        ) as database1, 
        (SELECT group_concat(TABLE_NAME) 
            FROM information_schema.TABLES
            WHERE TABLE_SCHEMA = 'database2' 
            AND engine = 'MyIsam'
        ) as database2,
        (SELECT group_concat(TABLE_NAME) 
            FROM information_schema.TABLES
            WHERE TABLE_SCHEMA = 'database3' 
            AND engine = 'MyIsam'
         ) as database3;

सादर।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.