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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

030_jdbc-mysql事务

發(fā)布時(shí)間:2025/4/17 数据库 67 豆豆
生活随笔 收集整理的這篇文章主要介紹了 030_jdbc-mysql事务 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1. 事務(wù)概念

1.1. 事務(wù)(Transaction)其實(shí)指的是一組操作, 里面包含許多個(gè)單一的邏輯。只要有一個(gè)邏輯沒有執(zhí)行成功, 那么都算失敗。所有的數(shù)據(jù)都回歸到最初的狀態(tài)。

2. 為什么要有事務(wù)?

2.1. 為了確保邏輯的成功。例子: 銀行的轉(zhuǎn)賬。

3. 事務(wù)的特性

3.1. 原子性(Atomicity): 指的是事務(wù)是一個(gè)不可分割的工作單位, 事務(wù)中的多個(gè)操作要么都發(fā)生, 要么都不發(fā)生。

3.2. 一致性(Consistency): 指的是事務(wù)執(zhí)行前后, 數(shù)據(jù)的完整性沒有被破環(huán)。比如A向B轉(zhuǎn)了錢, 轉(zhuǎn)賬前后錢的總數(shù)不變。

3.3. 隔離性(Isolation):?指的是多個(gè)用戶并發(fā)訪問數(shù)據(jù)數(shù)據(jù)庫時(shí), 一個(gè)用戶的事務(wù)不能被其他用戶的事務(wù)所干擾, 多個(gè)并發(fā)事務(wù)之間的數(shù)據(jù)相互隔離。比如事務(wù)A和事務(wù)B都修改同一條記錄,?這條記錄就會(huì)被重復(fù)修改或者后者會(huì)覆蓋前者的修改記錄。

3.4. 持久性(Durability):?指的是事務(wù)完成后,?事務(wù)對(duì)數(shù)據(jù)庫的更新被保存到數(shù)據(jù)庫, 其結(jié)果是永久的。

4. 查詢和關(guān)閉事務(wù)的自動(dòng)提交

5. 事務(wù)的操作步驟

5.1. 開啟事務(wù): start transaction。

5.2. 提交事務(wù)commit, 數(shù)據(jù)將會(huì)寫到數(shù)據(jù)庫。

5.3. 回滾事務(wù)rollback, 數(shù)據(jù)回滾到最初的狀態(tài)。

5.4. 事務(wù)只是針對(duì)連接對(duì)象, 如果再開一個(gè)連接對(duì)象, 那么默認(rèn)是自動(dòng)提交的。

6. 創(chuàng)建一張account表, 并插入2條數(shù)據(jù)。

7. 演示事務(wù)

8. 事務(wù)例子

8.1. 新建一個(gè)JDBC_Transaction工程, 使用我們之前的JDBCUtil.java和jdbc.properties屬性文件

8.2. 事務(wù)

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.關(guān)閉事務(wù)自動(dòng)提交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.拋一個(gè)除數(shù)為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.提交事務(wù)conn.commit();} catch (SQLException e) {try {// 6.回滾事務(wù)conn.rollback();} catch (SQLException e1) {e1.printStackTrace();}e.printStackTrace();} finally {JDBCUtil.release(conn, ps, rs);}} }

8.3. 運(yùn)行前查看id為1和2的錢分別是2000和1000

8.4. 運(yùn)行出錯(cuò), id為1和2的錢還是2000和1000

8.5. 注釋掉會(huì)拋異常的代碼

8.6. 運(yùn)行后沒有出錯(cuò), id為1的人的錢變?yōu)?900, id為2的人的錢變?yōu)?100

總結(jié)

以上是生活随笔為你收集整理的030_jdbc-mysql事务的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。