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

InnoDB-tabeller findes i MySQL, men siger, at de ikke eksisterer efter kopiering af database til ny server

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



  1. 10 nyttige tips om MySQL-indstilling af ydeevne

  2. Betinget kolonne til forespørgsel baseret på andre kolonner i MySQL

  3. Hvordan får du sikkert og effektivt række-id'et efter et insert med mysql ved hjælp af MySQLdb i python?

  4. Det ultimative emoji-kodningsskema