[导读]在windows服务器中如果你使用mysql数据库是很容易出现表损失这个问题了,特别是重启服务器时没有先停止mysql数据库
在windows服务器中如果你使用mysql数据库是很容易出现表损失这个问题了,特别是重启服务器时没有先停止mysql数据库这样出现几乎很高哦,下面来给各位朋友介绍一下操作步骤。
表损坏的症状
一个损坏的表的典型症状如下:
1 、当在从表中选择数据之时,你得到如下错误:
Incorrect key file for table: '...'. Try to repair it
2 、查询不能在表中找到行或返回不完全的数据。
3 、Error: Table 'p' is marked as crashed and should be repaired 。
4 、打开表失败: Can't open file: ‘×××.MYI' (errno: 145) 。
mysql命令修复数据库表
用”repair table”方式修复
语法:repair table 表名 [选项]
选项如下:
QUICK 用在数据表还没被修改的情况下,速度最快
EXTENDED 试图去恢复每个数据行,会产生一些垃圾数据行,万般无奈的情况下用
USE_FRM 用在.MYI文件丢失或者头部受到破坏的情况下。利用.frm的定义来重建索引
多数情况下,简单得用”repair table tablename”不加选项就可以搞定问题。但是当.MYI文件丢失或者头部受到破坏时,这样的方式不管用,这时索引文件丢失或者其头部遭到了破坏,为了利用相关定义文件来修复,需要用USE_FRM选项。
REPAIR TABLE 用于修复被破坏的表REPAIR TABLE `table_name` 修复表 (只对MyISAM引擎有效)
OPTIMIZE TABLE `table_name` 优化表
其他类型的损坏需要从备份中恢复。
1,REPAIR TABLE SQL statement (mysql服务必须处于运行状态)。
2,命令mysqlcheck (mysql服务可以处于运行状态)。
3,命令myisamchk (必须停掉mysql服务,或者所操作的表处于不活动状态)。
MySQL数据库的修复
找到mysql的安装目录的bin/myisamchk工具,在命令行中输入