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

|| 我使用mysqldump导出数据库,然后将其导入到其他服务器上的MySQL中。现在,如果我执行“显示表”,则可以看到我的所有表,但是我实际上无法选择或描述其中的任何一个。   错误1146(42S02):表\'mydatabase.user \'不存在 我所有的表都是InnoDB。我看到人们在使用old_passwords的地方遇到了一个问题,因此我在my.cnf中将其明确设置为0,并确保mysql表中的所有密码均为41个十六进制数字,因为新密码应为十六进制数字。     
已邀请:
“显示表;”起作用的原因是因为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)运行SHOW ENGINES;并确保InnoDB完全正常运行! 4)将mysqldump重新加载到新的导入服务器中 试试看 !!!     
从Windows服务器更改为Linux服务器时,出现了此问题。 表是文件,而Windows文件是区分大小写的,但是linux文件是区分大小写的。 在我的应用中,在sql查询中,有时我使用大写的表名,而另一些时候则使用小写的表名,因此,有时我获得的结果与您相同。     
我的情况是
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) \' - \"\'\"
    

要回复问题请先登录注册