030_jdbc-mysql事务
1. 事務概念
1.1. 事務(Transaction)其實指的是一組操作, 里面包含許多個單一的邏輯。只要有一個邏輯沒有執行成功, 那么都算失敗。所有的數據都回歸到最初的狀態。
2. 為什么要有事務?
2.1. 為了確保邏輯的成功。例子: 銀行的轉賬。
3. 事務的特性
3.1. 原子性(Atomicity): 指的是事務是一個不可分割的工作單位, 事務中的多個操作要么都發生, 要么都不發生。
3.2. 一致性(Consistency): 指的是事務執行前后, 數據的完整性沒有被破環。比如A向B轉了錢, 轉賬前后錢的總數不變。
3.3. 隔離性(Isolation):?指的是多個用戶并發訪問數據數據庫時, 一個用戶的事務不能被其他用戶的事務所干擾, 多個并發事務之間的數據相互隔離。比如事務A和事務B都修改同一條記錄,?這條記錄就會被重復修改或者后者會覆蓋前者的修改記錄。
3.4. 持久性(Durability):?指的是事務完成后,?事務對數據庫的更新被保存到數據庫, 其結果是永久的。
4. 查詢和關閉事務的自動提交
5. 事務的操作步驟
5.1. 開啟事務: start transaction。
5.2. 提交事務commit, 數據將會寫到數據庫。
5.3. 回滾事務rollback, 數據回滾到最初的狀態。
5.4. 事務只是針對連接對象, 如果再開一個連接對象, 那么默認是自動提交的。
6. 創建一張account表, 并插入2條數據。
7. 演示事務
8. 事務例子
8.1. 新建一個JDBC_Transaction工程, 使用我們之前的JDBCUtil.java和jdbc.properties屬性文件
8.2. 事務
package com.lywgames.myjdbc;import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import com.lywgames.util.JDBCUtil;public class MyJDBC {public static void main(String[] args) {Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;try {conn = JDBCUtil.getConn();// 1.關閉事務自動提交conn.setAutoCommit(false);// 2.扣除用戶1的錢ps = conn.prepareStatement("update account set money = money - ? where id = ?");ps.setInt(1, 100);ps.setInt(2, 1);ps.executeUpdate();// 3.拋一個除數為0異常int v = 2 / 0;JDBCUtil.closeSt(ps);// 4.給用戶2加錢ps = conn.prepareStatement("update account set money = money + ? where id = ?");ps.setInt(1, 100);ps.setInt(2, 2);ps.executeUpdate();// 5.提交事務conn.commit();} catch (SQLException e) {try {// 6.回滾事務conn.rollback();} catch (SQLException e1) {e1.printStackTrace();}e.printStackTrace();} finally {JDBCUtil.release(conn, ps, rs);}} }8.3. 運行前查看id為1和2的錢分別是2000和1000
8.4. 運行出錯, id為1和2的錢還是2000和1000
8.5. 注釋掉會拋異常的代碼
8.6. 運行后沒有出錯, id為1的人的錢變為1900, id為2的人的錢變為1100
總結
以上是生活随笔為你收集整理的030_jdbc-mysql事务的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 032_jdbc-mysql批量操作
- 下一篇: 033_jdbc-mysql数据库连接池