6

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

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

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

4

3 回答 3

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)清理 InnoDB 设置

3) 运行显示引擎;并确保 InnoDB 完全可操作!!!

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

试试看 !!!

于 2011-05-25T21:40:24.997 回答
2

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

在我的应用程序中,在 sql 查询中,有时我使用大写的表名,有时使用小写,所以,有时我得到了和你一样的结果。

于 2011-05-25T22:32:08.117 回答
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) ' - "'"
于 2013-04-03T13:00:22.893 回答