mysqlcheck和myisamchk都可以用来检测和修复表。(主要是MyISAM表)
但是也有以下不同点:
1.都可以检查、分析和修复myisam表。但是mysqlcheck也可以检查、分析innodb表;myisamchk可以enabling、disabling索引。
2.mysqlcheck是客户端工具,通过网络与mysql server连接,要求server必须是在线的;myisamchk不是客户端程序,可以直接在myisam表上操作。
3.mysqlcheck是通过mysql server自身对表进行检查和修复;myisamchk要求被检测表是没有被打开、或未被使用,如果myisamchk和mysql server同时对表操作,可能导致表被损坏。
mysqlcheck有三种使用模式,取决于用户如何调用它:
1.mysqlcheck默认的第一个参数是数据库名:
> mysqlcheck testdb
第一个参数后面的参数被认为是数据库中对应的表:
> mysqlcheck testdb table1 table2
2.也可以使用参数--databases(-B)指定多个数据库:
> mysqlcheck --databases db1 db2 db3
3.检查所有的数据库:
> mysqlcheck --all-databases
myisamchk默认是检查表
1.检查表(也可以使用索引文件)
> myisamchk table1 > myisamchk table1.MYI
2.修复表
> myisamchk -recover table1
其它参数参考文档!