当前位置:Gxlcms > PHP教程 > 自动修复crashed的数据表

自动修复crashed的数据表

时间:2021-07-01 10:21:17 帮助过:14人阅读

mysql crashed

  1. function check_table($table){
  2. require dirname(__FILE__) .'/connection.php';
  3. mysql_select_db("news",$db);
  4. $ret = mysql_query("SHOW TABLE STATUS WHERE `name` = '".$table."'");
  5. while($row = mysql_fetch_array($ret)){
  6. if($row['Engine']!='MyISAM'){
  7. $wrong=1;
  8. }
  9. }
  10. if($wrong){
  11. mysql_query("REPAIR TABLE ".$table);
  12. }
  13. mysql_close($db);
  14. $wrong=$ret=$row=NULL;}

上面的代码是不是可以检查数据表是否crashed?
crashed的数据表是不是 $row['Engine'] = null?
没找到相关的文章,求助各位前辈。


回复讨论(解决方案)

13.5.2.6. REPAIR TABLE语法
REPAIR [LOCAL | NO_WRITE_TO_BINLOG] TABLE
tbl_name [, tbl_name] ... [QUICK] [EXTENDED] [USE_FRM]
REPAIR TABLE用于修复被破坏的表。默认情况下,REPAIR TABLE与myisamchk --recover tbl_name具有相同的效果。REPAIR TABLE 对MyISAM和ARCHIVE表起作用。
而你却是在 !='MyISAM' 的条件下执行 REPAIR TABLE

13.5.2.6. REPAIR TABLE语法
REPAIR [LOCAL | NO_WRITE_TO_BINLOG] TABLE
tbl_name [, tbl_name] ... [QUICK] [EXTENDED] [USE_FRM]
REPAIR TABLE用于修复被破坏的表。默认情况下,REPAIR TABLE与myisamchk --recover tbl_name具有相同的效果。REPAIR TABLE 对MyISAM和ARCHIVE表起作用。
而你却是在 !='MyISAM' 的条件下执行 REPAIR TABLE


数据表格式为MyISAM,当数据表错误时,在phpmyadmin里显示表的状态为in use。
那么,怎么样的mysql语句,可以检查数据表错误,然后执行REPAIR TABLE语句?
谢谢。

好像应该是

  1. if($row["Collation"]=='in use'){

对吗?

人气教程排行