InnoDB表存在于MySQL中,但表示在将数据库复制到新服务器后它们不存在

时间:2011-05-25 17:14:02

标签: mysql innodb mysqldump mysql-error-1146 my.cnf

我使用mysqldump导出我的数据库然后将其导入到我的其他服务器上的MySQL中。如果我“显示表格”,我现在可以看到我的所有表格,但我实际上无法从中选择或描述它们。

  

ERROR 1146(42S02):表'mydatabase.user'不存在

我的所有表都是InnoDB。我看到人们在使用old_passwords的地方有一个问题,所以我在my.cnf中明确地将其设置为0,并且我确保mysql表中的所有密码都是41个十六进制数字,因为它们应该用于新密码。

3 个答案:

答案 0 :(得分:7)

“显示表格”的原因工作是因为mysqld只扫描数据库目录中的.frm文件。只要它们存在,它就会看到一个表定义。

如果您将数据导入MySQL并发生此错误消息,我将立即执行的第一件事就是运行此命令:(顺便说一句,这是MySQL 5.1.45,但无论如何都适用于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)

如果您将数据导入InnoDB的服务器被禁用,那么您就遇到了一个大问题。这是你应该做的:

1)从新导入数据库服务器中删除所有数据

2)Cleanup InnoDB Setup

3)运行SHOW ENGINES;并确保InnoDB完全正常运行!!!

4)将mysqldump重新加载到新的导入服务器

试一试!!!

答案 1 :(得分:2)

当我从Windows服务器更改为Linux服务器时,我遇到了这个问题。 表是文件,windows文件是大小写的,但linux文件区分大小写。

在我的应用程序中,在sql查询中,有时我使用大写的表名,有时候使用小写,所以,有时候我得到的结果与你相同。

答案 2 :(得分:0)

我的情况是SQLCA.DBParm参数。

我使用SQLCA.DBParm = "Databse = "sle_database.text"",但必须是

SQLCA.DBParm = "Database='" +sle_database.text+ "'"

解释:你要结合三个字符串:

a) Database='               - "Database='"

b) (name of the database)   - +sle_database.text+

c) ' - "'"