導航:首頁 > 程序命令 > mysql表修復命令

mysql表修復命令

發布時間:2024-10-22 06:39:52

1. MySQL表卡死怎麼辦25字教你快速解決mysql一張表卡死

MySQL表卡死怎麼辦?25字教你快速解決!
MySQL是一個廣泛使用的關系型資料庫管理系統,但有時候當操作大數據量或者復雜查詢時,會遇到MySQL表卡死的情況,這會讓我們非常苦惱。那麼,該怎麼辦呢?下面是一個簡單並有效的解決方案,只需25字即可快速解決!
解決方案:使用OPTIMIZE TABLE 命令
優化MySQL表是一種系統保障措施,尤其在表結構很復雜,有大量存儲數據的情況下,這一指令會節省大量的系統資源,幫助該錶快速刷新。使用 OPTIMIZE TABLE是優化MySQL表非常有效的方法,只需在MySQL客戶端中輸入以下命令即可:
OPTIMIZE TABLE table_name;
此命令意思為:對表table_name進行優化操作。其中table_name指待處理的表名。
通過使用該命令,MySQL表的執行效率會得到提高,從而避免表卡死的問題。
不過要注意,優化過程中會佔用較高的系統資源,因此優化過程需要慎重選擇時機和操作。
了解優化MySQL表後如何快速解決表卡死問題是很必要的操作。掌握這一技巧,即可在日常的資料庫維護上更加得心應手,提高數據處理效率,提升工作效率。

2. 鎬庢牱淇澶峬ysql琛

澶氭暟鎯呭喌涓,鏁版嵁搴撹鐮村潖鍙鏄鎸囩儲寮曟枃浠跺彈鍒頒簡鐮村潖,鐪熸g殑鏁版嵁琚鐮村潖鎺夌殑鎯呭喌闈炲父灝戙傚ぇ澶氭暟褰㈠紡鐨勬暟鎹搴撶牬鍧忕殑鐨勪慨澶嶇浉褰撶畝鍗曘
鍜屽墠闈㈢殑鏍¢獙涓鏍,淇澶嶇殑鏂瑰紡涔熸湁涓夌嶃
涓嬮潰璁茬殑鏂規硶鍙瀵筂yISAM鏍煎紡鐨勮〃鏈夋晥銆傚叾浠栫被鍨嬬殑鎹熷潖闇瑕佷粠澶囦喚涓鎮㈠嶃
1,REPAIR TABLE SQL statement(mysql鏈嶅姟蹇呴』澶勪簬榪愯岀姸鎬)銆
2,鍛戒護mysqlcheck(mysql鏈嶅姟鍙浠ュ勪簬榪愯岀姸鎬)銆
3,鍛戒護myisamchk(蹇呴』鍋滄帀mysql鏈嶅姟,鎴栬呮墍鎿嶄綔鐨勮〃澶勪簬涓嶆椿鍔ㄧ姸鎬)銆
鍦ㄤ慨澶嶈〃鐨勬椂鍊,鏈濂藉厛浣滀竴涓嬪囦喚銆傛墍浠ヤ綘闇瑕佷袱鍊嶄簬鍘熷嬭〃澶у皬鐨勭‖鐩樼┖闂淬傝風『淇濆湪榪涜屼慨澶嶅墠浣犵殑紜鐩樼┖闂磋繕娌℃湁鐢ㄥ畬銆
1>鐢ㄢ漴epair table鈥濇柟寮忎慨澶
璇娉:repair table 琛ㄥ悕 [閫夐」]
閫夐」濡備笅:
QUICK 鐢ㄥ湪鏁版嵁琛ㄨ繕娌¤淇鏀圭殑鎯呭喌涓,閫熷害鏈蹇
EXTENDED 璇曞浘鍘繪仮澶嶆瘡涓鏁版嵁琛,浼氫駭鐢熶竴浜涘瀮鍦炬暟鎹琛,涓囪埇鏃犲堢殑鎯呭喌涓嬬敤
USE_FRM 鐢ㄥ湪.MYI鏂囦歡涓㈠け鎴栬呭ご閮ㄥ彈鍒扮牬鍧忕殑鎯呭喌涓嬨傚埄鐢.frm鐨勫畾涔夋潵閲嶅緩緔㈠紩
澶氭暟鎯呭喌涓,綆鍗曞緱鐢ㄢ漴epair table tablename鈥濅笉鍔犻夐」灝卞彲浠ユ悶瀹氶棶棰樸備絾鏄褰.MYI鏂囦歡涓㈠け鎴栬呭ご閮ㄥ彈鍒扮牬鍧忔椂,榪欐牱鐨勬柟寮忎笉綆$敤,渚嬪:
mysql> REPAIR TABLE mytable;
+鈥斺斺斺斺斺斺斺-+鈥斺斺+鈥斺斺-+鈥斺斺斺斺斺斺斺斺斺斺斺斺斺斺+
| Table | Op | Msg_type | Msg_text |
+鈥斺斺斺斺斺斺斺-+鈥斺斺+鈥斺斺-+鈥斺斺斺斺斺斺斺斺斺斺斺斺斺斺+
| sports_results.mytable | repair | error | Can鈥檛 find file: 鈥榤ytable.MYI鈥 (errno: 2) |
+鈥斺斺斺斺斺斺斺-+鈥斺斺+鈥斺斺-+鈥斺斺斺斺斺斺斺斺斺斺斺斺斺斺+
淇澶嶅け璐ョ殑鍘熷洜鏃剁儲寮曟枃浠朵涪澶辨垨鑰呭叾澶撮儴閬鍒頒簡鐮村潖,涓轟簡鍒╃敤鐩稿叧瀹氫箟鏂囦歡鏉ヤ慨澶,闇瑕佺敤USE_FRM閫夐」銆備緥濡:
mysql> REPAIR TABLE mytable USE_FRM;
+鈥斺斺斺斺斺斺斺-+鈥斺斺+鈥斺斺-+鈥斺斺斺斺斺斺斺斺斺斺斺+
| Table | Op | Msg_type | Msg_text |
+鈥斺斺斺斺斺斺斺-+鈥斺斺+鈥斺斺-+鈥斺斺斺斺斺斺斺斺斺斺斺+
| sports_results.mytable | repair | warning | Number of rows changed from 0 to 2 |
| sports_results.mytable | repair | status | OK |
+鈥斺斺斺斺斺斺斺-+鈥斺斺+鈥斺斺-+鈥斺斺斺斺斺斺斺斺斺斺斺+
鎴戜滑鍙浠ョ湅鍒癕sg_test琛ㄩ」鐨勮緭鍑轟俊鎮鈥漮k鈥,琛ㄥ悕宸茬粡鎴愬姛淇澶嶅彈鎹熻〃銆
2>鐢╩ysql鍐呭緩鍛戒護mysqlcheck鏉ヤ慨澶
褰搈ysql鏈嶅姟鍦ㄨ繍琛屾椂,涔熷彲浠ョ敤mysql鍐呭緩鍛戒護mysqlcheck鏉ヤ慨澶嶃
璇娉:mysqlcheck -r 鏁版嵁搴撳悕 琛ㄥ悕 -uuser -ppass
%mysqlcheck -r sports_results mytable -uuser -ppass
sports_results.mytable OK
鍒╃敤mysqlcheck鍙浠ヤ竴嬈℃т慨澶嶅氫釜琛ㄣ傚彧瑕佸湪鏁版嵁搴撳悕鍚庡垪鍑虹浉搴旇〃鍚嶅嵆鍙(鐢ㄧ┖鏍奸殧寮)銆傛垨鑰呮暟鎹搴撳悕鍚庝笉鍔犺〃鍚,灝嗕細淇澶嶆暟鎹搴撲腑鐨勬墍鏈夎〃,渚嬪:
%mysqlcheck -r sports_results mytable events -uuser -ppass
sports_results.mytable OK
sports_results.events OK

%mysqlcheck -r sports_results -uuser -ppass
sports_results.mytable OK
sports_results.events OK
3>鐢╩yisamchk淇澶
鐢ㄨ繖縐嶆柟寮忔椂,mysql鏈嶅姟蹇呴』鍋滄帀,鎴栬呮墍鎿嶄綔鐨勮〃澶勪簬涓嶆椿鍔ㄧ姸鎬(閫夐」skip-external-locking娌¤浣跨敤)銆傝扮潃涓瀹氳佸湪鐩稿叧.MYI鏂囦歡鐨勮礬寰勪笅鎴栬呰嚜宸卞畾涔夊叾璺寰勩
璇娉:myisamchk [閫夐」] [琛ㄥ悕]
涓嬮潰鏄鍏墮夐」鍜屾弿榪
鈥揵ackup, -B 鍦ㄨ繘琛屼慨澶嶅墠浣滅浉鍏寵〃寰楀囦喚
鈥揷orrect-checksum 綰犳f牎楠屽拰
鈥揹ata-file-length=#, -D # 閲嶅緩琛ㄦ椂,鎸囧畾鏁版嵁鏂囦歡寰楁渶澶ч暱搴
鈥揺xtend-check, -e 璇曞浘鍘繪仮澶嶆瘡涓鏁版嵁琛,浼氫駭鐢熶竴浜涘瀮鍦炬暟鎹琛,涓囪埇鏃犲堢殑鎯呭喌涓嬬敤
鈥揻orce, -f 褰撻亣鍒版枃浠跺悕鐩稿悓鐨.TMD鏂囦歡鏃,灝嗗叾瑕嗙洊鎺夈
keys-used=#, -k # 鎸囧畾鎵鐢ㄧ殑keys鍙鍔犲揩澶勭悊閫熷害,姣忎釜浜岃繘鍒朵綅浠h〃涓涓猭ey.絎涓涓猭ey涓0
鈥搑ecover, -r 鏈甯哥敤鐨勯夐」,澶у氭暟鐮村潖閮藉彲浠ラ氳繃瀹冩潵淇澶嶃傚傛灉浣犵殑鍐呭瓨瓚沖熷ぇ,鍙浠ュ炲ぇ鍙傛暟sort_buffer_size鐨勫兼潵鍔犲揩鎮㈠嶇殑閫熷害銆備絾鏄閬囧埌鍞涓閿鐢變簬鐮村潖鑰屼笉鍞涓 鐨勮〃鏃,榪欑嶆柟寮忎笉綆$敤銆
鈥搒afe-recover 錛峯 鏈褰誨簳鐨勪慨澶嶆柟寮,浣嗘槸姣-r鏂瑰紡鎱,涓鑸鍦-r淇澶嶅け璐ュ悗鎵嶄嬌鐢ㄣ傝繖縐嶆柟寮忚誨嚭 鎵鏈夌殑琛,騫朵互琛屼負鍩虹鏉ラ噸寤虹儲寮曘傚畠鐨勭‖鐩樼┖闂撮渶奼傛瘮-r鏂瑰紡紼嶅井灝忎竴鐐,鍥 涓哄畠娌″壋寤哄垎綾葷紦瀛樸備綘鍙浠ュ炲姞key_buffer_size鐨勫兼潵鍔犲揩淇澶嶇殑閫熷害銆
鈥搒ort-recover, -n mysql鐢ㄥ畠綾誨垎綾葷儲寮,灝界$粨鏋滄槸涓存椂鏂囦歡浼氶潪甯稿ぇ
鈥揷haracter-sets-dir=鈥 鍖呭惈瀛楃﹂泦璁劇疆鐨勭洰褰
鈥搒et-character-set=name 涓虹儲寮曞畾涔変竴涓鏂扮殑瀛楃﹂泦
鈥搕mpdir=path, -t 濡傛灉浣犱笉鎯崇敤鐜澧冨彉閲廡MPDIR鐨勫肩殑璇,鍙浠ヨ嚜瀹氫箟涓存椂鏂囦歡鐨勫瓨鏀句綅緗
鈥搎uick, -q 鏈蹇鐨勪慨澶嶆柟寮,褰撴暟鎹鏂囦歡娌℃湁琚淇鏀規椂鐢,褰撳瓨鍦ㄥ氶敭鏃,絎浜屼釜-q灝嗕細淇鏀 鏁版嵁鏂囦歡
鈥搖npack, -u 瑙e紑琚玬yisampack鎵撳寘鐨勬枃浠
myisamchk搴旂敤鐨勪竴涓渚嬪瓙
% myisamchk -r mytable
- recovering (with keycache) MyISAM-table 鈥榤ytable.MYI鈥

3. 如何修復MySQL資料庫表

有兩種方法,一種方法使用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伺服器必須沒有啟動!檢測修復所有資料庫(表)

閱讀全文

與mysql表修復命令相關的資料

熱點內容
王者伺服器上限了怎麼辦 瀏覽:321
單片機rp2什麼意思 瀏覽:413
php獲取https請求 瀏覽:64
編譯原理這門課講了什麼 瀏覽:693
php開發微信教程 瀏覽:703
預防醫學pdf 瀏覽:493
推薦演算法java實現 瀏覽:81
肖秀榮2018pdf 瀏覽:250
pspdf亂碼了 瀏覽:667
python定義字典數組 瀏覽:295
編譯bios 瀏覽:659
自己編寫python框架 瀏覽:596
vf命令編號 瀏覽:578
怎麼解決excel編譯錯誤 瀏覽:939
什麼電視app可以免費看戲曲 瀏覽:929
圖形界面登陸linux 瀏覽:856
python簡單還是php簡單 瀏覽:216
華為方舟編譯器首秀大牛力捧 瀏覽:635
cxf動態編譯問題 瀏覽:727
特斯拉密鑰怎麼加密 瀏覽:319