Pokaż tabele według silnika w MySQL

84

Jak pokazałbym wszystkie tabele w MySQL z danym silnikiem, np. InnoDB, MyISAM, FEDERATED?

Kit Peters
źródło

Odpowiedzi:

130

Użyj INFORMATION_SCHEMA.TABLEStabeli:

SELECT table_name FROM INFORMATION_SCHEMA.TABLES
  WHERE engine = 'InnoDB'
ChssPly76
źródło
4
Możesz także potrzebować schematu z tym, aby zapytanie wyglądało tak: SELECT TABLE_SCHEMA, TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE engine = 'InnoDB'
Dan Bowling
81

Jeśli chcesz wyniki z jednej bazy danych

SELECT TABLE_NAME FROM information_schema.TABLES
    WHERE TABLE_SCHEMA = 'dbname' AND engine = 'InnoDB';
Alvin
źródło
1
Oznaczyłem to, ponieważ prawdopodobnie chcesz spojrzeć tylko na określony schemat
Csaba Toth
6

Inne przykłady tutaj.

Wszystkie tabele według silnika (z wyjątkiem tabel systemowych):

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

Wszystkie tabele z wyjątkiem silnika (z wyjątkiem tabel systemowych):

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');
MTK
źródło
1

Jeśli ktoś ma problem i chce zobaczyć w której bazie danych znajdują się tabele z określonym silnikiem

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;

Pozdrowienia.

Stevan Tosic
źródło