回覆列表
  • 1 # 使用者3494949202203

    有兩種方法,一種方法使用mysql的check table和repair table 的sql語句,另一種方法是使用MySQL提供的多個myisamchk, isamchk資料檢測恢復工具。前者使用起來比較簡便。推薦使用。

    1. check table 和 repair table

    登陸mysql 終端:

    mysql -uxxxxx -p dbname

    check table tabTest;

    如果出現的結果說Status是OK,則不用修復,如果有Error,可以用:

    repair table tabTest;

    進行修復,修復之後可以在用check table命令來進行檢查。在新版本的phpMyAdmin裡面也可以使用check/repair的功能。

    2. myisamchk, isamchk

    其中myisamchk適用於MYISAM型別的資料表,而isamchk適用於ISAM型別的資料表。這兩條命令的主要引數相同,一般新的系統都使用MYISAM作為預設的資料表型別,這裡以myisamchk為例子進行說明。當發現某個資料表出現問題時可以使用:

    myisamchk tablename.MYI

    進行檢測,如果需要修復的話,可以使用:

    myisamchk -of tablename.MYI

    關於myisamchk的詳細引數說明,可以參見它的使用幫助。需要注意的時在進行修改時必須確保MySQL伺服器沒有訪問這個資料表,保險的情況下是最好在進行檢測時把MySQL伺服器Shutdown掉。

    另外可以把下面的命令放在你的rc.local裡面啟動MySQL伺服器前:

    [ -x /tmp/mysql.sock ] && /pathtochk/myisamchk -of /DATA_DIR/*/*.MYI

    其中的/tmp/mysql.sock是MySQL監聽的Sock檔案位置,對於使用RPM安裝的使用者應該是/var/lib/mysql/mysql.sock,對於使用原始碼安裝則是/tmp/mysql.sock可以根據自己的實際情況進行變更,而pathtochk則是myisamchk所在的位置,DATA_DIR是你的MySQL資料庫存放的位置。

    需要注意的時,如果你打算把這條命令放在你的rc.local裡面,必須確認在執行這條指令時MySQL伺服器必須沒有啟動!檢測修復所有資料庫(表)

  • 中秋節和大豐收的關聯?
  • 建行手機銀行每天轉賬限額怎麼調整?