JDBC事務

来源:http://www.cnblogs.com/caigq/archive/2017/07/30/7049276.html
-Advertisement-
Play Games

事務概述事務指的是邏輯上的一組操作(多條sql語句),組成這組操作的各個單元要麼全都成功,要麼全都失敗. 事務的作用保證在一個事務中多次操作要麼全都成功,要麼全都失敗. mysql事務操作Connection介面中有和事務有關的方法: void setAutoCommit(boolean autoC ...


事務概述
事務指的是邏輯上的一組操作(多條sql語句),組成這組操作的各個單元要麼全都成功,要麼全都失敗.

事務的作用
保證在一個事務中多次操作要麼全都成功,要麼全都失敗.

mysql事務操作
Connection介面中有和事務有關的方法:
void setAutoCommit(boolean autoCommit) 將此連接的自動提交模式設置為給定狀態。
autoCommit - 為 true 表示啟用自動提交模式;為 false 表示禁用自動提交模式
要把autoCommit設置為false,讓事務手動開啟
void commit() 如果多條sql都執行成功,提交事務
void rollback() 有一條sql執行失敗,就回滾事務,把數據回滾到開啟事務之前的狀態

代碼實現

 1 public class Demo01Account {
 2     public static void main(String[] args) {
 3         Connection conn = null;
 4         Statement stat = null;
 5         try {
 6             //註冊驅動
 7             Class.forName("com.mysql.jdbc.Driver");
 8             //獲取連接
 9             conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day06", "root", "root");
10             //開啟事物
11             conn.setAutoCommit(false);
12             //獲取執行者對象
13             stat = conn.createStatement();
14             int i = stat.executeUpdate("update account set money=money-100 where name='tom'");
15             int num = 0/0;//tom錢減少了,jerry錢沒有增加
16             int j = stat.executeUpdate("update account set money=money+100 where name='jerry'");
17             if(i>0 && j>0){
18                 System.out.println("轉賬成功!");
19             }
20             //提交事物
21             conn.commit();
22         } catch (Exception e) {
23             e.printStackTrace();
24             //回滾事物
25             try {
26                 conn.rollback();
27             } catch (SQLException e1) {
28                 e1.printStackTrace();
29             }
30         }finally{
31             if (stat != null){
32                 try {
33                     stat.close();
34                 } catch (Exception e) {
35                     e.printStackTrace();
36                 }
37             }
38             if (conn != null){
39                 try {
40                     conn.close();
41                 } catch (Exception e) {
42                     e.printStackTrace();
43                 }
44             }
45         }
46         
47     }
48 }

 事務的特性

原子性:強調事務的不可分割.多條語句要麼都成功,要麼都失敗。
一致性:強調的是事務的執行的前後,數據要保持一致.
隔離性:一個事務的執行不應該受到其他事務的干擾.
持久性:事務一旦結束(提交/回滾)數據就持久保持到了資料庫.

如果不考慮事務的隔離性,引發一些安全性問題
臟讀:一個事務讀到另一個事務還沒有提交的數據.
臟讀又稱無效數據的讀出,是指在資料庫訪問中,事務T1將某一值修改,然後事務T2讀取該值,此後T1因為某種原因撤銷對該值的修改,這就導致了T2所讀取到的數據是無效的
不可重覆讀:一個事務讀到了另一個事務已經提交的update的數據,導致在當前的事務中多次查詢結果不一致.
虛讀/幻讀 :一個事務讀到另一個事務已經提交的insert的數據,導致在當前的事務中多次的查詢結果不一致.

解決引發的讀問題
設置事務的隔離級別:級別超高,越安全,效率越低。
1 read uncommitted :未提交讀.臟讀,不可重覆讀,虛讀都可能發生.
2 read committed :已提交讀.避免臟讀.但是不可重覆讀和虛讀有可能發生.(Oracle預設)
4 repeatable read :可重覆讀.避免臟讀,不可重覆讀.但是虛讀有可能發生.(MySql預設)
8 serializable :串列化的.避免臟讀,不可重覆讀,虛讀的發生.


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 回來寫博客,少年前端時間被django迷了心魄 如果轉載,請註明博文來源: www.cnblogs.com/xinysu/ ,版權歸 博客園 蘇家小蘿蔔 所有。望各位支持! 如果轉載,請註明博文來源: www.cnblogs.com/xinysu/ ,版權歸 博客園 蘇家小蘿蔔 所有。望各位支持! ...
  • 在mysql中,篩選非空的時候經常會用到is not null和!=null,這兩種方法單從字面上來看感覺是差不多的,其實如果去運行一下試試的話差別會很大!為什麼會出現這種情況呢?null 表示什麼也不是, 不能=、>、< … 所有的判斷,結果都是false,所有隻能用 is null進行判斷。預設 ...
  • 目錄 · 概述 · 原理 · 組成 · 執行流程 · 性能 · API · 應用程式模板 · 通用讀寫方法 · RDD轉為DataFrame · Parquet文件數據源 · JSON文件數據源 · Hive數據源 · 資料庫JDBC數據源 · DataFrame Operation · 性能調優 ...
  • 背景 最近我們在替換生產環境的資料庫伺服器的時候,因該實例下庫比較多,差不多有近200個庫,加上維護視窗的時間有限,所以我們有必要寫段腳本快速批量附加所有的庫,並確保所有的庫都附加成功。當前的情況是所有的庫名都是唯一且不存在庫名相似的情形,如 db_1 和 db_12 不存在這種庫名相似的情況。 環 ...
  • 靜默安裝參考:http://www.cnblogs.com/colmeluna/p/5686142.html 實際安裝中: 1.跳過了第二步設定交換區空間 2.安裝完成後沒有提示執行orainstRoot.sh,只有root.sh 建庫參考:http://www.cnblogs.com/jyzhao ...
  • 本文出處:http://www.cnblogs.com/wy123/p/7259866.html(保留出處並非什麼原創作品權利,本人拙作還遠遠達不到,僅僅是為了鏈接到原文,因為後續對可能存在的一些錯誤進行修正或補充,無他) 與其他數據一樣,記憶體對資料庫的性能有著至關重要的影響,MySQL InnoD ...
  • 在Sql Server 2012之前,實現分頁主要是使用ROW_NUMBER(),在SQL Server2012,可以使用Offset ...Rows Fetch Next ... Rows only的方式去實現分頁數據查詢。 上面代碼中,column1,column2 ... columnN表示實 ...
  • 作為開源資料庫的新手,近日有興對比了Pg和MySQL的查詢計劃。 通過Pg源碼目錄下的src\backend\executor\README文件,加上一些簡單調試,就能對Pg的執行機制產生一個初步印象;而MySQL的代碼可讀性比Pg差了不少,可能還要花些時日去瞭解先。 原本想寫一篇執行機制對比的文章 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...