Mysql
 sql >> Datenbank >  >> RDS >> Mysql

InnoDB-Tabellen existieren in MySQL, sagen aber, dass sie nach dem Kopieren der Datenbank auf einen neuen Server nicht existieren

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

2) InnoDB-Setup bereinigen

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 !!!