Comment puis-je montrer toutes les tables de MySQL avec un moteur donné, par exemple InnoDB, MyISAM, FÉDÉRÉ?Afficher les tables par moteur MySQL
70
A
Répondre
114
Utilisez le tableau INFORMATION_SCHEMA.TABLES
:
SELECT table_name FROM INFORMATION_SCHEMA.TABLES
WHERE engine = 'InnoDB'
66
Si vous voulez que les résultats d'une seule base de données
SELECT TABLE_NAME FROM information_schema.TABLES
WHERE TABLE_SCHEMA = 'dbname' AND engine = 'InnoDB';
+1
Je marqué parce que vous voulez probablement loo k à un certain schéma seulement –
1
Si certains a un problème et que vous voulez voir dans laquelle DB est des tables avec moteur spécifique
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;
Cordialement.
4
D'autres exemples ici.
Toutes les tables par le moteur (sauf les tables système):
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');
Toutes les tables, à l'exception du moteur (sauf les tables système):
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');
Questions connexes
- 1. Afficher les éléments par emplacement. Mysql Sélectionnez
- 2. php mysql afficher par vues
- 3. Afficher les tables FULLTEXT colonnes indexées
- 4. mysql comparer les tables
- 5. Mysql joindre les tables question
- 6. Groupe MySQL par colonnes multiples sur les tables jointes (WordPress)
- 7. Requête MySql, combiner les tables
- 8. Comment joindre les tables MySQL
- 9. mysql - tables syndicales par champ unique
- 10. Grandes tables MySQL
- 11. Changement de moteur de table dans MySQL
- 12. joindre deux tables MySQL
- 13. Comparer 2 tables MySQL avec PHP et les afficher avec les différences
- 14. Compteur d'index partagé par plusieurs tables dans mysql
- 15. Colonnes dynamiques dans les tables mysql?
- 16. renommer les tables colonnes dans mysql
- 17. Comment puis-je définir le moteur de stockage par défaut utilisé par MySQL?
- 18. PHP, MySQL et les tables temporaires
- 19. MySQL - Afficher toutes les permutations
- 20. Comptage de tables différentes dans les tables MySQL MyISAM
- 21. Fusionner deux tables MySQL
- 22. Requêtes multi-tables MySQL
- 23. MySQL Rejoindre trois tables
- 24. MySql tables mutliple
- 25. MySQL if/else pour les tables
- 26. Mysql Choisissez parmi les différentes tables
- 27. mysql btree index sur les tables InnoDB?
- 28. MySQL: Comment grouper les tables en catégories?
- 29. Comment supprimer toutes les tables dans MySQL?
- 30. Script PHP pour peupler les tables MySQL
Vous pouvez également le schéma avec cela, de sorte que la requête ressemblerait à ceci: SELECT TABLE_SCHEMA, TABLE_NAME dE INFORMATION_SCHEMA.TABLES OU moteur = « InnoDB » –