Mysql事務操作失敗如何解決
事務的原子性 :事務是數(shù)據(jù)庫的邏輯工作單位,事務中包含的各操作要么都做,要么都不做 。
要實現(xiàn)事務的原子性,單單靠一條commit或是rollback命令還是不行的,因為例如commit命令它只是將一個事務中執(zhí)行成功的DML語句提交給數(shù)據(jù)庫里。如果要實現(xiàn)事務的原子性,則就需要commit和rollback命令配合上程序上的一個業(yè)務邏輯才能可以,具體業(yè)務邏輯代碼如下示例代碼:
1.現(xiàn)象
程序中打開了事務進行插入,但是沒有commit,表中的數(shù)據(jù)已經(jīng)存在,就是回滾也不能刪除插入的數(shù)據(jù)
2.原因
本表的Storage Engine 為myisam,不是innoDB,不支持事務處理 rollback()
3.解決方法
使用 alter table xxxx engine = innoDB ; 將表改為 InnoDB 引擎,結果回滾正常。
4.代碼
private void testCrud() {
Connection conn = null; //連接對象
PreparedStatement pstmt = null; //預編譯的SQL語句對象
try{
//加載MySQL驅動程序
Class.forName("com.mysql.jdbc.Driver");
//連接字符串
String url = "jdbc:mysql://localhost:3306/test";
//建立數(shù)據(jù)庫連接
conn = DriverManager.getConnection(url,"root","");
//設置事務的隔離級別
// conn.setTransactionIsolation(Connection. TRANSACTION_REPEATABLE_READ);
//設置自動提交為false,開始事務
conn.setAutoCommit(false);
//帶參數(shù)的更新語句
String sql = "INSERT INTO user_info (username ,password ,age )values(?,?,?)";
//準備語句
pstmt = conn.prepareStatement(sql);
//綁定參數(shù),執(zhí)行更新語句,將張三的賬戶金額減去1000元
pstmt.setString(1, "zhangui");
pstmt.setString(2, "1111");
pstmt.setInt(3, 300);
pstmt.execute();
//綁定參數(shù),執(zhí)行更新語句,將李四的賬戶金額增加1000元
// pstmt.setString(1, "zzzzzzzzzzzzzzzzz"); //綁定了非法參數(shù)
//pstmt.setString(2, "1111111111");
//pstmt.setInt(3, 500);
//pstmt.execute(); //將拋出SQL異常
//提交事務
//conn.commit();
System.out.println("事務已提交,轉賬成功!");
//關閉語句、連接
pstmt.close(); conn.close();
}catch(Exception e){
try{
conn.rollback(); //回滾事務
System.out.println("事務回滾成功,沒有任何記錄被更新!");
}catch(Exception re){
System.out.println("回滾事務失??!");
}
e.printStackTrace();
}finally{
if(pstmt!=null) try{pstmt.close();}catch(Exception ignore){}
if(conn!=null) try{conn.close();}catch(Exception ignore){}
}
}
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
您可能感興趣的文章:- Mysql事務處理詳解
- 通過實例分析MySQL中的四種事務隔離級別
- 解決Mysql收縮事務日志和日志文件過大無法收縮問題
- mysql的存儲過程、游標 、事務實例詳解
- PHP mysqli事務操作常用方法分析
- MySQL四種事務隔離級別詳解
- NodeJs使用Mysql模塊實現(xiàn)事務處理實例
- MySQL數(shù)據(jù)庫事務隔離級別詳解
- MySQL事務的基礎學習以及心得分享