Årsagen til "vis tabeller;" fungerer, fordi mysqld kun scanner databasemappen for .frm-filer. Så længe de eksisterer, ser den en tabeldefinition.
Hvis du importerede dataene til MySQL, og denne fejlmeddelelse opstår, er den første ting, jeg straks vil gøre, at køre denne kommando:(BTW Dette er MySQL 5.1.45, men virker i MySQL 5.x alligevel)
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)
Hvis serveren, du importerede dataene til, siger, at InnoDB er deaktiveret, har du et stort problem. Her er, hvad du skal gøre:
1) Slip alle data fra den nye import-DB-server
2) Opsætning af InnoDB oprydning
3) køre SHOW ENGINES; og sørg for, at InnoDB er fuldt operationel !!!
4) Genindlæs mysqldump til den nye importserver
Prøv det!!!