有兩種方法,一種方法使用mysql的check table和repair table 的sql語句,另一種方法是使用MySQL提供的多個(gè)myisamchk, isamchk數(shù)據(jù)檢測(cè)恢復(fù)工具。前者使用起來比較簡(jiǎn)便。推薦使用。
創(chuàng)新互聯(lián)建站是一家企業(yè)級(jí)云計(jì)算解決方案提供商,超15年IDC數(shù)據(jù)中心運(yùn)營(yíng)經(jīng)驗(yàn)。主營(yíng)GPU顯卡服務(wù)器,站群服務(wù)器,遂寧服務(wù)器托管,海外高防服務(wù)器,服務(wù)器機(jī)柜,動(dòng)態(tài)撥號(hào)VPS,海外云手機(jī),海外云服務(wù)器,海外服務(wù)器租用托管等。
1. check table 和 repair table
登陸mysql 終端:
mysql -uxxxxx -p dbname
check table tabTest;
如果出現(xiàn)的結(jié)果說Status是OK,則不用修復(fù),如果有Error,可以用:
repair table tabTest;
進(jìn)行修復(fù),修復(fù)之后可以在用check table命令來進(jìn)行檢查。在新版本的phpMyAdmin里面也可以使用check/repair的功能。
2. myisamchk, isamchk
其中myisamchk適用于MYISAM類型的數(shù)據(jù)表,而isamchk適用于ISAM類型的數(shù)據(jù)表。這兩條命令的主要參數(shù)相同,一般新的系統(tǒng)都使用MYISAM作為缺省的數(shù)據(jù)表類型,這里以myisamchk為例子進(jìn)行說明。當(dāng)發(fā)現(xiàn)某個(gè)數(shù)據(jù)表出現(xiàn)問題時(shí)可以使用:
myisamchk tablename.MYI
進(jìn)行檢測(cè),如果需要修復(fù)的話,可以使用:
myisamchk -of tablename.MYI
關(guān)于myisamchk的詳細(xì)參數(shù)說明,可以參見它的使用幫助。需要注意的時(shí)在進(jìn)行修改時(shí)必須確保MySQL服務(wù)器沒有訪問這個(gè)數(shù)據(jù)表,保險(xiǎn)的情況下是最好在進(jìn)行檢測(cè)時(shí)把MySQL服務(wù)器Shutdown掉。
-----------------------------
另外可以把下面的命令放在你的rc.local里面啟動(dòng)MySQL服務(wù)器前:
[ -x /tmp/mysql.sock ] /pathtochk/myisamchk -of /DATA_DIR/*/*.MYI
其中的/tmp/mysql.sock是MySQL監(jiān)聽的Sock文件位置,對(duì)于使用RPM安裝的用戶應(yīng)該是/var/lib/mysql/mysql.sock,對(duì)于使用源碼安裝則是/tmp/mysql.sock可以根據(jù)自己的實(shí)際情況進(jìn)行變更,而pathtochk則是myisamchk所在的位置,DATA_DIR是你的MySQL數(shù)據(jù)庫存放的位置。
需要注意的時(shí),如果你打算把這條命令放在你的rc.local里面,必須確認(rèn)在執(zhí)行這條指令時(shí)MySQL服務(wù)器必須沒有啟動(dòng)!檢測(cè)修復(fù)所有數(shù)據(jù)庫(表)
import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Connection;import java.sql.Statement; public class MysqlDemo { public static void main(String[] args) throws Exception { Connection conn = null; String sql; // MySQL的JDBC URL編寫方式:jdbc:mysql://主機(jī)名稱:連接端口/數(shù)據(jù)庫的名稱?參數(shù)=值 // 避免中文亂碼要指定useUnicode和characterEncoding // 執(zhí)行數(shù)據(jù)庫操作之前要在數(shù)據(jù)庫管理系統(tǒng)上創(chuàng)建一個(gè)數(shù)據(jù)庫,名字自己定, // 下面語句之前就要先創(chuàng)建javademo數(shù)據(jù)庫 String url = "jdbc:mysql://localhost:3306/javademo?" + "user=rootpassword=rootuseUnicode=truecharacterEncoding=UTF8"; try { // 之所以要使用下面這條語句,是因?yàn)橐褂肕ySQL的驅(qū)動(dòng),所以我們要把它驅(qū)動(dòng)起來, // 可以通過Class.forName把它加載進(jìn)去,也可以通過初始化來驅(qū)動(dòng)起來,下面三種形式都可以 Class.forName("com.mysql.jdbc.Driver");// 動(dòng)態(tài)加載mysql驅(qū)動(dòng) // or: // com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver(); // or: // new com.mysql.jdbc.Driver(); System.out.println("成功加載MySQL驅(qū)動(dòng)程序"); // 一個(gè)Connection代表一個(gè)數(shù)據(jù)庫連接 conn = DriverManager.getConnection(url); // Statement里面帶有很多方法,比如executeUpdate可以實(shí)現(xiàn)插入,更新和刪除等 Statement stmt = conn.createStatement(); sql = "create table student(NO char(20),name varchar(20),primary key(NO))"; int result = stmt.executeUpdate(sql);// executeUpdate語句會(huì)返回一個(gè)受影響的行數(shù),如果返回-1就沒有成功 if (result != -1) { System.out.println("創(chuàng)建數(shù)據(jù)表成功"); sql = "insert into student(NO,name) values('2012001','陶偉基')"; result = stmt.executeUpdate(sql); sql = "insert into student(NO,name) values('2012002','周小俊')"; result = stmt.executeUpdate(sql); sql = "select * from student"; ResultSet rs = stmt.executeQuery(sql);// executeQuery會(huì)返回結(jié)果的集合,否則返回空值 System.out.println("學(xué)號(hào)\t姓名"); while (rs.next()) { System.out .println(rs.getString(1) + "\t" + rs.getString(2));// 入如果返回的是int類型可以用getInt() } } } catch (SQLException e) { System.out.println("MySQL操作錯(cuò)誤"); e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { conn.close(); } } }
我們?nèi)绻ㄟ^ODBC連接MYSQL就需要配置MYSQL驅(qū)動(dòng),那么如何在ODBC數(shù)據(jù)源中配置MYSQL驅(qū)動(dòng)呢?
工具/材料
ODBC數(shù)據(jù)源管理器
操作方法
01、首先要下載MYSQL驅(qū)動(dòng)程序,點(diǎn)擊驅(qū)動(dòng)程序進(jìn)入安裝界面,點(diǎn)擊Next按鈕
02、在彈出的安裝類型界面中選擇Typical類型。
03、然后按Win+R組合鍵打開運(yùn)行界面,輸入control命令。
04、接下來在控制面板中點(diǎn)擊管理工具選項(xiàng)。
05、然后進(jìn)入管理工具我們點(diǎn)擊ODBC數(shù)據(jù)源選項(xiàng),這里大家根據(jù)自己的系統(tǒng)版本選擇即。
06、在彈出的ODBC數(shù)據(jù)源管理程序界面中點(diǎn)擊右側(cè)的添加按鈕。
07、然后進(jìn)入創(chuàng)建數(shù)據(jù)源界面,這里選擇MySQL ODBC 8.0 Unicode Driver選項(xiàng)。
08、接著我們配置Mysql的連接地址和用戶名密碼即可。
09、然后點(diǎn)擊Test按鈕,如果彈出如下圖所示的提示則代表連接成功。
10、最后我們點(diǎn)擊確定就可以將MySQL的驅(qū)動(dòng)程序加載進(jìn)ODBC數(shù)據(jù)源管理程序中了。
操作方法
01、首先要下載MYSQL驅(qū)動(dòng)程序,點(diǎn)擊驅(qū)動(dòng)程序進(jìn)入安裝界面,點(diǎn)擊Next按鈕
02、在彈出的安裝類型界面中選擇Typical類型。
03、然后按Win+R組合鍵打開運(yùn)行界面,輸入control命令。
04、接下來在控制面板中點(diǎn)擊管理工具選項(xiàng)。
05、然后進(jìn)入管理工具我們點(diǎn)擊ODBC數(shù)據(jù)源選項(xiàng),這里大家根據(jù)自己的系統(tǒng)版本選擇即。
06、在彈出的ODBC數(shù)據(jù)源管理程序界面中點(diǎn)擊右側(cè)的添加按鈕。
07、然后進(jìn)入創(chuàng)建數(shù)據(jù)源界面,這里選擇MySQL ODBC 8.0 Unicode Driver選項(xiàng)。
08、接著我們配置Mysql的連接地址和用戶名密碼即可。
09、然后點(diǎn)擊Test按鈕,如果彈出如下圖所示的提示則代表連接成功。
10、最后我們點(diǎn)擊確定就可以將MySQL的驅(qū)動(dòng)程序加載進(jìn)ODBC數(shù)據(jù)源管理程序中了。