我使用mysqldump导出数据库,然后将其导入到其他服务器上的MySQL中。 现在,如果我执行"显示表格",则可以看到我的所有表格,但实际上无法选择或描述任何表格。
ERROR 1146 (42S02): Table 'mydatabase.user' doesn't exist
我所有的表都是InnoDB。 我看到一个人在哪里使用old_passwords的问题,因此我在my.cnf中将其明确设置为0,并确保mysql表中的所有密码均为41个十六进制数字,因为新密码应为十六进制数字。
您确定还原没有错误吗? 尝试使用单个事务进行还原,该事务将因错误而停止。
在我将其复制后,它已经工作了一段时间,然后它开始说该表不存在。 但是我无法创建表,因为它确实存在...问题是导入后此副本发生的数据有一些更改,因此我至少需要能够访问这些更改。 该表的.frm文件与数据库的工作副本完全相同。
看来您的表格结构有问题。 不能帮助您。 尝试在启用日志的情况下进行全新还原,并将日志中的任何错误发布到此处。
原因是"显示表格";起作用是因为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) ' -"'"