How would I show all tables in MySQL with a given engine, e.g. InnoDB, MyISAM, FEDERATED?
Show tables by engine in MySQL
72.6k Views Asked by Aurelia Peters At
        	4
        	
        There are 4 best solutions below
1
                
                        
                            
                        
                        
                            On
                            
                                                    
                    
                If you want the results from a single database
SELECT TABLE_NAME FROM information_schema.TABLES
    WHERE TABLE_SCHEMA = 'dbname' AND engine = 'InnoDB';
                        0
                
                        
                            
                        
                        
                            On
                            
                                                    
                    
                If some has problem and want to see in which DB is tables with specific engine
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;
Regards.
0
                
                        
                            
                        
                        
                            On
                            
                                                    
                    
                Other examples here.
All tables by engine (except system tables):
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');
All tables except engine (except system tables):
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');
                        
Use
INFORMATION_SCHEMA.TABLEStable: