Mysql
 sql >> Database >  >> RDS >> Mysql

Le tabelle InnoDB esistono in MySQL ma afferma che non esistono dopo aver copiato il database sul nuovo server

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