Der Grund "Tabellen anzeigen;" funktioniert, liegt daran, dass mysqld das Datenbankverzeichnis nur nach .frm-Dateien durchsucht. Solange sie existieren, sieht es eine Tabellendefinition.
Wenn Sie die Daten in MySQL importiert haben und diese Fehlermeldung auftritt, würde ich als erstes sofort diesen Befehl ausführen:(Übrigens ist dies MySQL 5.1.45, funktioniert aber trotzdem 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)
Wenn der Server, in den Sie die Daten importiert haben, sagt, dass InnoDB deaktiviert ist, haben Sie ein großes Problem. Folgendes sollten Sie tun:
1) Löschen Sie alle Daten vom neuen Import-DB-Server
3) starte SHOW ENGINES; und stellen Sie sicher, dass InnoDB voll funktionsfähig ist !!!
4) Laden Sie mysqldump erneut auf den neuen Importserver
Probieren Sie es aus !!!