请问Mysql 采用复制目录的方式备份还原,执行操作会出现Incorrect key file for table '表名'; try to repair it,为什么,如何解决

xyshx 2008-03-03 05:24:10
我有个mysql的源数据库,源版本不详
只有数据库文件目录,就是那些.frm,.myi,.myd文件
现在用装了
mysql 5.1 建立一个与所拥有的数据文件的数据库名一样的数据库,并把现有的数据库文件目录覆盖新建的数据库文件目录,
使用mysql命令可以显示表名,但是执行select等命令时
会出现Incorrect key file for table '表名'; try to repair it
请问这是为什么,该如何解决?
或者我如何恢复这个数据库?
谢谢
...全文
881 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
懒得去死 2008-03-10
  • 打赏
  • 举报
回复
chmod -R 660 你的数据库目录,然后就OK了。
xyshx 2008-03-10
  • 打赏
  • 举报
回复
问题已经解决,其实是版本问题,源数据库是4.X版本的
我开始用5.X版本的
所以不行
这个问题就送分吧。
likelynn 2008-03-07
  • 打赏
  • 举报
回复
OPTIMIZE TABLE
懒得去死 2008-03-07
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 likelynn 的回复:]
OPTIMIZE TABLE
[/Quote]

这个是整理表碎片的,不是修复表的!
懒得去死 2008-03-04
  • 打赏
  • 举报
回复
try to repair it



  通常情况下,即使MyISAM表格式非常可靠(SQL语句对表做的所有改变在语句返回之前被写下),如果下列任何事件发生,你依然可以获得损坏的表:

  · mysqld进程在写中间被杀掉。
  · 发生未预期的计算机关闭(例如,计算机被关闭)。
  · 硬件故障。
  · 你可以同时在正被服务器修改的表上使用外部程序(如myisamchk)。
  · MySQL或MyISAM代码的软件缺陷。

  一个损坏的表的典型症状如下:
  · 当在从表中选择数据之时,你得到如下错误:
  · Incorrect key file for table: '...'. Try to repair it
  · 查询不能在表中找到行或返回不完全的数据。

  你可以用CHECK TABLE statement语句来检查MyISAM表的健康,并用REPAIR TABLE修复一个损坏的MyISAM表。当mysqld不运行之时,你也可以用myisamchk命令检查或修理一个表。

  如果你的表变得频繁损坏,你应该试着确定为什么会这样的原因。要明白的最重要的事是表变得损坏是不是因为服务器崩溃的结果。你可以在错误日志中查找最近的restarted mysqld消息来早期验证这个。如果存在这样一个消息,则表损坏是服务器死掉的一个结果是很有可能的。否则,损坏可能在正常操作中发生。这是一个缺陷。你应该试着创建一个展示这个问题的可重复生成的测试案例。
wildlily980 2008-03-03
  • 打赏
  • 举报
回复
repair table table_name

56,677

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧