sql >> Databáze >  >> RDS >> Mysql

Tabulky InnoDB existují v MySQL, ale říkají, že po zkopírování databáze na nový server neexistují

Důvod "zobrazit tabulky;" funguje to proto, že mysqld prohledá adresář databáze pouze na soubory .frm. Dokud existují, vidí definici tabulky.

Pokud jste importovali data do MySQL a objeví se tato chybová zpráva, první věc, kterou bych okamžitě udělal, je spustit tento příkaz:(BTW Toto je MySQL 5.1.45, ale stejně funguje v 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)

Pokud server, do kterého jste importovali data, říká, že InnoDB je zakázáno, pak máte velký problém. Zde je to, co byste měli udělat:

1) Odstraňte všechna data z nového importního DB serveru

2) Vyčištění InnoDB Setup

3) spusťte SHOW ENGINES; a ujistěte se, že InnoDB je plně funkční !!!

4) Znovu načtěte mysqldump do nového importovacího serveru

Vyzkoušejte to !!!



  1. 5 triků pro zajištění špičkového výkonu serveru SQL

  2. Je primární klíč automaticky indexován v MySQL?

  3. Jak zadat číslo portu v připojovacím řetězci SQL Server?

  4. Chyba syntaxe v příkazu MERGE