Показать таблицы по движку в MySQL

84

Как мне показать все таблицы в MySQL с заданным движком, например InnoDB, MyISAM, FEDERATED?

Кит Питерс
источник

Ответы:

130

INFORMATION_SCHEMA.TABLESТаблица использования :

SELECT table_name FROM INFORMATION_SCHEMA.TABLES
  WHERE engine = 'InnoDB'
ЧссПлы76
источник
4
Вам также может понадобиться схема с этим, поэтому запрос будет выглядеть так: SELECT TABLE_SCHEMA, TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE engine = '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');
MTK
источник
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;

С уважением.

Стеван Тошич
источник