Il motivo "mostra tabelle;" funziona perché mysqld eseguirà la scansione della directory del database solo per i file .frm. Finché esistono, vede una definizione di tabella.
Se hai importato i dati in MySQL e si verifica questo messaggio di errore, la prima cosa che farei immediatamente è eseguire questo comando:(BTW Questo è MySQL 5.1.45, ma funziona comunque in MySQL 5.x)
mysql> show engines;
+------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine | Support | Comment | Transactions | XA | Savepoints |
+------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB | YES | Supports transactions, row-level locking, and foreign keys | YES | YES | YES |
| MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO |
| BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO |
| CSV | YES | CSV storage engine | NO | NO | NO |
| MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO |
| FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL |
| ARCHIVE | YES | Archive storage engine | NO | NO | NO |
| MyISAM | DEFAULT | Default engine as of MySQL 3.23 with great performance | NO | NO | NO |
+------------+---------+----------------------------------------------------------------+--------------+------+------------+
8 rows in set (0.00 sec)
Se il server in cui hai importato i dati dice che InnoDB è disabilitato, allora hai un grosso problema. Ecco cosa dovresti fare:
1) Elimina tutti i dati dal nuovo server DB di importazione
2) Ripulisci la configurazione di InnoDB
3) eseguire MOSTRA MOTORI; e assicurati che InnoDB sia completamente operativo!!!
4) Ricarica il mysqldump nel nuovo server di importazione
Provalo!!!