日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL数据库的回滚失败(JAVA)

發布時間:2023/11/30 数据库 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL数据库的回滚失败(JAVA) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這幾天在學習MySQL數據的知識,有一個小測試,用來測試數據庫的提交和回滾。

剛開始的時候真的沒把這個當回事,按照正常的步驟來講的話,如下所示,加載驅動,獲取數據庫的連接,并且把數據庫的自動提交給關閉掉。

1 //加載驅動 2 Class.forName(driver); 3 //獲取數據庫的連接 4 connection = DriverManager.getConnection(url, user, password); 5 //關閉數據庫事務的自動提交,默認值為true 6 connection.setAutoCommit(false);

在做測試的時候,自己使用的是建表語句,總共三句話,最后一句是錯誤的,按照正常情況來講,執行錯誤語句以后,程序會跳轉到catch代碼塊中,執行回滾語句。但是在刷新數據庫以后,查看數據庫中的表格,會發現數據庫多了兩張表,前兩條語句執行成功,并沒有回滾。

1 String[] sqls={ 2 "create table A (Sno varchar(100) ,Sname varchar(20))", 3 "create table B (Cno varchar(100) ,Cname varchar(20))", 4 "create table C (Sno varchar(100),Cno varchar(100),Grade )" 5 }; 6 7 Connection connection = JDBCUtil.getConnection();//獲取數據庫的連接 8 try { 9 10 Statement stmt=connection.createStatement(); 11 12 for(String sql:sqls){ 13 stmt.execute(sql); 14 } 15 16 connection.commit(); //提交事務 17 } catch (SQLException e) { 18 e.printStackTrace(); 19 try { 20 21 connection.rollback();//事務的回滾 22 } catch (SQLException e1) { 23 // TODO Auto-generated catch block 24 e1.printStackTrace(); 25 } 26 27 28 }

后來在網上查了一些資料,得知在MySQL中,對表的創建、刪除和更改表結構等操作是回滾無效的,DDL操作直接觸發隱式提交,任何事務回滾的前提是沒有commit,隱式提交直接執行commit了,后續的rollback對前面的語句無效。如果想對建表語句回滾的話,可以在catch語句塊里面,模擬回滾操作,判斷表格否存在,存在就刪除即可。

轉載于:https://www.cnblogs.com/tudou1179006580/p/9159005.html

總結

以上是生活随笔為你收集整理的MySQL数据库的回滚失败(JAVA)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。