多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > 數據庫 > 數據庫應用 > JDBC編程-事務編程(四)

JDBC編程-事務編程(四)

來源:程序員人生   發布時間:2015-06-01 09:04:44 閱讀次數:3430次

事務的概念

事務的概念在我看來是指的是1組sql序列,這個序列是1塊履行的單位,要末全部履行,要不全部履行,這樣可以很好的對數據庫進行并發控制。
由于數據庫是多個用戶都可以同時操作的,如果多個用戶同時操作1個數據,就容易造成數據的不1致,所以事務作為并發控制的1個基本單位很有必要。

事務的特性

1.原子性:事務是1個完全的整體,所有的操作和數據都是1個整體。
2.1致性:事務的操作是1致性的。
3.隔離性:事務之間的操作是相互隔離的。
4.持久性:事務的操作是持久的,即便出現了毛病也會完成。

事務的語句

BEGIN TRANSACTION
COMMIT TRANSACTION
ROLLBACK TRANSACTION

實驗代碼

public static Statement getStatement(){ Statement st = null; try { Class.forName("com.mysql.jdbc.Driver"); Connection conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/jsp_dbb", "root", ""); st = (Statement) conn.createStatement(); } catch (Exception e) { // TODO: handle exception } return st; } public static void insertUserData(){ try { String sql = "INSERT INTO tbl_user(id,name,password,email)" + "VALUES(10,'Tom','123456','tom@qq.com')"; Statement st = getStatement(); int count = st.executeUpdate(sql); System.out.println("插入了"+count+"行用戶數據"); } catch (Exception e) { // TODO: handle exception e.printStackTrace(); } } public static void insertAddressData(){ try { String sql = "INSERT INTO tbl_address(id,city,country,user_id)" + "VALUES(1,'shanghai','china,'10')"; Statement st = getStatement(); int count = st.executeUpdate(sql); System.out.println("插入了"+count+"行地址數據"); } catch (Exception e) { // TODO: handle exception e.printStackTrace(); } } public static void main(String[] args) { insertUserData(); insertAddressData(); }

這段代碼會報錯,由于在tbl_address中已有id = 1的數據了,具體以下圖:

插入了1行用戶數據 com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '10')' at line 1 at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:377) at com.mysql.jdbc.Util.getInstance(Util.java:360) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:978) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3887) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3823) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2435) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2582) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2526) at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1618) at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1549) at liu.peng.jdbc.TransactionTest.insertAddressData(TransactionTest.java:37) at liu.peng.jdbc.TransactionTest.main(TransactionTest.java:46)

檢查發現只是插入user表的數據,沒有插入address表數據,造成數據不完全。

事務處理的利用

事務處理的核心代碼就是
conn.setAutoCommit(false);
在履行完以后的提交。
conn.commit();
和在捕獲異常時候的回滾。
具體代碼以下:

public static Connection getConnection(){ Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/jsp_dbb", "root", ""); } catch (Exception e) { // TODO: handle exception } return conn; } public static void insertUserData(Connection conn)throws SQLException{ String sql = "INSERT INTO tbl_user(id,name,password,email)" + "VALUES(10,'Tom','123456','tom@qq.com')"; Statement st = (Statement) conn.createStatement(); int count = st.executeUpdate(sql); System.out.println("插入了"+count+"行用戶數據"); } public static void insertAddressData(Connection conn) throws SQLException{ String sql = "INSERT INTO tbl_address(id,city,country,user_id)" + "VALUES(1,'shanghai','china,'10')"; Statement st = (Statement) conn.createStatement(); int count = st.executeUpdate(sql); System.out.println("插入了"+count+"行地址數據"); } public static void main(String[] args) { Connection conn = null; try { conn = getConnection(); conn.setAutoCommit(false); insertUserData(conn); insertAddressData(conn); conn.commit(); } catch (SQLException e) { System.out.println("==========捕獲SQL異常========="); e.printStackTrace(); try { conn.rollback(); System.out.println("=======s事務回滾成功======="); } catch (Exception e2) { e2.printStackTrace(); } }finally{ try { if (conn != null) { conn.close(); } } catch (Exception e3) { e3.printStackTrace(); } } }

Console界面的報錯信息為:

插入了1行用戶數據 ==========捕獲SQL異常========= com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '10')' at line 1 at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:377) at com.mysql.jdbc.Util.getInstance(Util.java:360) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:978) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3887) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3823) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2435) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2582) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2526) at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1618) at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1549) at liu.peng.jdbc.TransactionTest.insertAddressData(TransactionTest.java:31) at liu.peng.jdbc.TransactionTest.main(TransactionTest.java:40) =======s事務回滾成功=======

證明兩條數據都沒有插入進去保證了數據的完全性,而第1次只是插入user表的數據,沒有插入address表數據,造成數據不完全。

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 黄色天堂| 一区二区三区高清不卡 | 国产亚洲欧美一区 | 国内自拍 亚洲系列 欧美系列 | 亚洲精品乱码久久久久久蜜桃欧美 | 久久大香伊人中文字幕 | 亚洲图片 自拍偷拍 | 精品国产人成亚洲区 | 成人自拍视频网站 | 国产精品卡哇伊小可爱在线观看 | 国产九九精品 | 亚洲在线播放视频 | 欧美巨大另类极品videosbest | 国产亚洲图片 | 五月激情婷婷综合 | 欧美专区亚洲专区 | 日本一级毛片在线看 | 国产区精品一区二区不卡中文 | 精品在线视频播放 | freexxx性欧美极品另类 | 99久久国产综合精品女不卡 | 国产99视频精品免视看7 | 亚洲人视频在线观看 | 一级aa毛片 | 久久免费国产精品一区二区 | 国内免费视频成人精品 | 一区二区三区久久 | japan色系videos强行 | 欧美亚洲桃花综合 | 伊人欧美在线 | 国产精品免费福利 | 亚洲精品自产拍在线观看 | 亚洲精品www久久久久久久软件 | 欧美亚洲国产日韩 | 激情综合婷婷丁香六月花 | 欧美日韩性生活 | 欧美日韩精选 | 欧美精品专区第1页 | 日韩欧美亚洲视频 | 亚洲免费视频网站 | 亚洲第一成人在线 |