Tabellen nach Engine in MySQL anzeigen


83

Wie würde ich alle Tabellen in MySQL mit einer bestimmten Engine anzeigen, z. B. InnoDB, MyISAM, FEDERATED?

Antworten:


129

Verwenden Sie INFORMATION_SCHEMA.TABLESTabelle:

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

4
Möglicherweise möchten Sie auch das Schema damit, sodass die Abfrage folgendermaßen aussehen würde: SELECT TABLE_SCHEMA, TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE engine = 'InnoDB'
Dan Bowling

81

Wenn Sie die Ergebnisse aus einer einzigen Datenbank erhalten möchten

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

1
Ich habe dies markiert, weil Sie wahrscheinlich nur ein bestimmtes Schema betrachten möchten
Csaba Toth

6

Andere Beispiele hier.

Alle Tabellen nach Engine (außer Systemtabellen):

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');

Alle Tabellen außer Engine (außer Systemtabellen):

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

Wenn einige Probleme haben und sehen möchten, in welcher Datenbank sich Tabellen mit einer bestimmten Engine befinden

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;

Grüße.

Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.