一個處理資料庫異常的類,按照錯誤碼彈出提示資訊

來源:互聯網
上載者:User

public class MyErrorContext
{
public static class MyError
{
int errno;
String szErrorDesc;
public MyError(int errno, String errorDesc)
{
this.errno = errno;
this.szErrorDesc = errorDesc;
}
public int getErrorNo()
{
return errno;
}
public String getErrorDesc()
{
return szErrorDesc;
}
}
public static final int DB_ER_CANT_create_TABLE = 1005; //建立表失敗
public static final int DB_ER_CANT_create_DB = 1006; //建立資料庫失敗
public static final int DB_ER_DB_create_EXISTS = 1007; //資料庫已存在,建立資料庫失敗
public static final int DB_ER_DB_drop_EXISTS = 1008; //資料庫不存在,刪除資料庫失敗
public static final int DB_ER_DB_drop_delete = 1009; //不能刪除資料庫檔案導致刪除資料庫失敗
public static final int DB_ER_DB_drop_RMDIR = 1010; //不能刪除資料目錄導致刪除資料庫失敗
public static final int DB_ER_CANT_delete_FILE = 1011; //刪除資料庫檔案失敗
public static final int DB_ER_CANT_FIND_SYSTEM_REC = 1012; //不能讀取系統資料表中的記錄
public static final int DB_ER_CHECKREAD = 1020; //記錄已被其他使用者修改
public static final int DB_ER_DISK_FULL = 1021; //硬碟剩餘空間不足,請加大硬碟可用空間
public static final int DB_ER_DUP_KEY = 1022; //關鍵字重複,更改記錄失敗
public static final int DB_ER_ERROR_ON_CLOSE = 1023; //關閉時發生錯誤
public static final int DB_ER_ERROR_ON_READ = 1024; //讀檔案錯誤
public static final int DB_ER_ERROR_ON_rename = 1025; //更改名字時發生錯誤
public static final int DB_ER_ERROR_ON_WRITE = 1026; //寫檔案錯誤
public static final int DB_ER_KEY_NOT_FOUND = 1032; //記錄不存在
public static final int DB_ER_OPEN_AS_READONLY = 1036; //資料表是唯讀,不能對它進行修改
public static final int DB_ER_OUTOFMEMORY = 1037; //系統記憶體不足,請重啟資料庫或重啟伺服器
public static final int DB_ER_OUT_OF_SORTMEMORY = 1038; //用於排序的記憶體不足,請增大排序緩衝區
public static final int DB_ER_CON_COUNT_ERROR = 1040; //已到達資料庫的最大串連數,請加大資料庫可用串連數
public static final int DB_ER_OUT_OF_RESOURCES = 1041; //系統記憶體不足
public static final int DB_ER_BAD_HOST_ERROR = 1042; //無效的主機名稱
public static final int DB_ER_HANDSHAKE_ERROR = 1043; //無效串連
public static final int DB_ER_DBACCESS_DENIED_ERROR = 1044; //目前使用者沒有訪問資料庫的許可權
public static final int DB_ER_ACCESS_DENIED_ERROR = 1045; //不能串連資料庫,使用者名稱或密碼錯誤
public static final int DB_ER_BAD_NULL_ERROR = 1048; //欄位不可為空
public static final int DB_ER_BAD_DB_ERROR = 1049; //資料庫不存在
public static final int DB_ER_TABLE_EXISTS_ERROR = 1050; //資料表已存在
public static final int DB_ER_BAD_TABLE_ERROR = 1051; //資料表不存在
public static final int DB_ER_BAD_FIELD_ERROR = 1054; //欄位不存在
public static final int DB_ER_EMPTY_QUERY = 1065; //無效的SQL語句,SQL語句為空白
public static final int DB_ER_IPSOCK_ERROR = 1081; //不能建立Socket串連
public static final int DB_ER_RECORD_FILE_FULL = 1114; //資料表已滿,不能容納任何記錄
public static final int DB_ER_TOO_MANY_TABLES = 1116; //開啟的資料表太多
public static final int DB_ER_HOST_IS_BLOCKED = 1129; //資料庫出現異常,請重啟資料庫
public static final int DB_ER_HOST_NOT_PRIVILEGED = 1130; //串連資料庫失敗,沒有串連資料庫的許可權
public static final int DB_ER_PASSWORD_NO_MATCH = 1133; //資料庫使用者不存在
public static final int DB_ER_NONEXISTING_GRANT = 1141; //目前使用者無權訪問資料庫
public static final int DB_ER_TABLEACCESS_DENIED_ERROR = 1142; //目前使用者無權訪問資料表
public static final int DB_ER_COLUMNACCESS_DENIED_ERROR = 1143; //目前使用者無權訪問資料表中的欄位
public static final int DB_ER_NO_SUCH_TABLE = 1146; //資料表不存在
public static final int DB_ER_NONEXISTING_TABLE_GRANT = 1147; //未定義使用者對資料表的存取權限
public static final int DB_ER_SYNTAX_ERROR = 1149; //SQL語句語法錯誤
public static final int DB_ER_NET_READ_ERROR = 1158; //網路錯誤,出現讀錯誤,請檢查網路連接狀況
public static final int DB_ER_NET_READ_INTERRUPTED = 1159; //網路錯誤,讀逾時,請檢查網路連接狀況
public static final int DB_ER_NET_ERROR_ON_WRITE = 1160; //網路錯誤,出現寫錯誤,請檢查網路連接狀況
public static final int DB_ER_NET_WRITE_INTERRUPTED = 1161; //網路錯誤,寫逾時,請檢查網路連接狀況
public static final int DB_ER_DUP_ENTRY = 1062; //欄位值重複,入庫失敗
public static final int DB_ER_DUP_UNIQUE = 1169; //欄位值重複,更新記錄失敗
public static final int DB_ER_CHECK_NO_SUCH_TABLE = 1177; //開啟資料表失敗
public static final int DB_ER_ERROR_DURING_COMMIT = 1180; //提交事務失敗
public static final int DB_ER_ERROR_DURING_ROLLBACK = 1181; //復原事務失敗
public static final int DB_ER_TOO_MANY_USER_CONNECTIONS = 1203; //目前使用者和資料庫建立的串連已到達資料庫的最大串連數,請增大可用的資料庫連接數或重啟資料庫
public static final int DB_ER_LOCK_WAIT_TIMEOUT = 1205; //加鎖逾時
public static final int DB_ER_NO_PERMISSION_TO_create_USER = 1211; //目前使用者沒有建立使用者的許可權
public static final int DB_ER_NO_REFERENCED_ROW = 1216; //外鍵約束檢查失敗,更新子表記錄失敗
public static final int DB_ER_ROW_IS_REFERENCED = 1217; //外鍵約束檢查失敗,刪除或修改主表記錄失敗
public static final int DB_ER_USER_LIMIT_REACHED = 1226; //目前使用者使用的資源已超過所允許的資源,請重啟資料庫或重啟伺服器
public static final int DB_ER_SPECIFIC_ACCESS_DENIED_ERROR = 1227; //許可權不足,您無權進行此操作
public static final int DB_ER_NOT_SUPPORTED_YET = 1235; //MySQL版本過低,不具有本功能
private static final MyError[] errormap =
{
new MyError(DB_ER_CANT_create_TABLE ,"建立表失敗"),
new MyError(DB_ER_CANT_create_DB ,"建立資料庫失敗"),
new MyError(DB_ER_DB_create_EXISTS ,"資料庫已存在,建立資料庫失敗"),
new MyError(DB_ER_DB_drop_EXISTS ,"資料庫不存在,刪除資料庫失敗"),
new MyError(DB_ER_DB_drop_delete ,"不能刪除資料庫檔案導致刪除資料庫失敗"),
new MyError(DB_ER_DB_drop_RMDIR ,"不能刪除資料目錄導致刪除資料庫失敗"),
new MyError(DB_ER_CANT_delete_FILE ,"刪除資料庫檔案失敗"),
new MyError(DB_ER_CANT_FIND_SYSTEM_REC ,"不能讀取系統資料表中的記錄"),
new MyError(DB_ER_CHECKREAD ,"記錄已被其他使用者修改"),
new MyError(DB_ER_DISK_FULL ,"硬碟剩餘空間不足,請加大硬碟可用空間"),
new MyError(DB_ER_DUP_KEY ,"關鍵字重複,更改記錄失敗"),
new MyError(DB_ER_ERROR_ON_CLOSE ,"關閉時發生錯誤"),
new MyError(DB_ER_ERROR_ON_READ ,"讀檔案錯誤"),
new MyError(DB_ER_ERROR_ON_rename ,"更改名字時發生錯誤"),
new MyError(DB_ER_ERROR_ON_WRITE ,"寫檔案錯誤"),
new MyError(DB_ER_KEY_NOT_FOUND ,"記錄不存在"),
new MyError(DB_ER_OPEN_AS_READONLY ,"資料表是唯讀,不能對它進行修改"),
new MyError(DB_ER_OUTOFMEMORY ,"系統記憶體不足,請重啟資料庫或重啟伺服器"),
new MyError(DB_ER_OUT_OF_SORTMEMORY ,"用於排序的記憶體不足,請增大排序緩衝區"),
new MyError(DB_ER_CON_COUNT_ERROR ,"已到達資料庫的最大串連數,請加大資料庫可用串連數"),
new MyError(DB_ER_OUT_OF_RESOURCES ,"系統記憶體不足"),
new MyError(DB_ER_BAD_HOST_ERROR ,"無效的主機名稱"),
new MyError(DB_ER_HANDSHAKE_ERROR ,"無效串連"),
new MyError(DB_ER_DBACCESS_DENIED_ERROR ,"目前使用者沒有訪問資料庫的許可權"),
new MyError(DB_ER_ACCESS_DENIED_ERROR ,"不能串連資料庫,使用者名稱或密碼錯誤"),
new MyError(DB_ER_BAD_NULL_ERROR ,"欄位不可為空"),
new MyError(DB_ER_BAD_DB_ERROR ,"資料庫不存在"),
new MyError(DB_ER_TABLE_EXISTS_ERROR ,"資料表已存在"),
new MyError(DB_ER_BAD_TABLE_ERROR ,"資料表不存在"),
new MyError(DB_ER_BAD_FIELD_ERROR ,"欄位不存在"),
new MyError(DB_ER_EMPTY_QUERY ,"無效的SQL語句,SQL語句為空白"),
new MyError(DB_ER_IPSOCK_ERROR ,"不能建立Socket串連"),
new MyError(DB_ER_RECORD_FILE_FULL ,"資料表已滿,不能容納任何記錄"),
new MyError(DB_ER_TOO_MANY_TABLES ,"開啟的資料表太多"),
new MyError(DB_ER_HOST_IS_BLOCKED ,"資料庫出現異常,請重啟資料庫"),
new MyError(DB_ER_HOST_NOT_PRIVILEGED ,"串連資料庫失敗,沒有串連資料庫的許可權"),
new MyError(DB_ER_PASSWORD_NO_MATCH ,"資料庫使用者不存在"),
new MyError(DB_ER_NONEXISTING_GRANT ,"目前使用者無權訪問資料庫"),
new MyError(DB_ER_TABLEACCESS_DENIED_ERROR ,"目前使用者無權訪問資料表"),
new MyError(DB_ER_COLUMNACCESS_DENIED_ERROR ,"目前使用者無權訪問資料表中的欄位"),
new MyError(DB_ER_NO_SUCH_TABLE ,"資料表不存在"),
new MyError(DB_ER_NONEXISTING_TABLE_GRANT ,"未定義使用者對資料表的存取權限"),
new MyError(DB_ER_SYNTAX_ERROR ,"SQL語句語法錯誤"),
new MyError(DB_ER_NET_READ_ERROR ,"網路錯誤,出現讀錯誤,請檢查網路連接狀況"),
new MyError(DB_ER_NET_READ_INTERRUPTED ,"網路錯誤,讀逾時,請檢查網路連接狀況"),
new MyError(DB_ER_NET_ERROR_ON_WRITE ,"網路錯誤,出現寫錯誤,請檢查網路連接狀況"),
new MyError(DB_ER_NET_WRITE_INTERRUPTED ,"網路錯誤,寫逾時,請檢查網路連接狀況"),
new MyError(DB_ER_DUP_ENTRY ,"欄位值重複,入庫失敗"),
new MyError(DB_ER_DUP_UNIQUE ,"欄位值重複,更新記錄失敗"),
new MyError(DB_ER_CHECK_NO_SUCH_TABLE ,"開啟資料表失敗"),
new MyError(DB_ER_ERROR_DURING_COMMIT ,"提交事務失敗"),
new MyError(DB_ER_ERROR_DURING_ROLLBACK ,"復原事務失敗"),
new MyError(DB_ER_TOO_MANY_USER_CONNECTIONS ,"目前使用者和資料庫建立的串連已到達資料庫的最大串連數,請增大可用的資料庫連接數或重啟資料庫"),
new MyError(DB_ER_LOCK_WAIT_TIMEOUT ,"加鎖逾時"),
new MyError(DB_ER_NO_PERMISSION_TO_create_USER ,"目前使用者沒有建立使用者的許可權"),
new MyError(DB_ER_NO_REFERENCED_ROW ,"外鍵約束檢查失敗,更新子表記錄失敗"),
new MyError(DB_ER_ROW_IS_REFERENCED ,"外鍵約束檢查失敗,刪除或修改主表記錄失敗"),
new MyError(DB_ER_USER_LIMIT_REACHED ,"目前使用者使用的資源已超過所允許的資源,請重啟資料庫或重啟伺服器"),
new MyError(DB_ER_SPECIFIC_ACCESS_DENIED_ERROR ,"許可權不足,您無權進行此操作"),
new MyError(DB_ER_NOT_SUPPORTED_YET ,"MySQL版本過低,不具有本功能"),
};
public static String getErrorInfo(int errno)
{
for(int i=0; i<errormap.length; i++)
{
if(errno == errormap[i].getErrorNo())
{
return errormap[i].getErrorDesc();
}
}
return "";
}
public String  getErrorMessage(int errorcode)
{
  String error=null;
for(int i=0; i<errormap.length; i++)
{
  if(errormap[i].getErrorNo()==errorcode)
  {
    error = errormap[i].getErrorNo() + ":" + errormap[i].getErrorDesc();
    break;
  }
}
return error;
}
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.