java事務——本地事務

来源:http://www.cnblogs.com/nobounds/archive/2016/04/20/5415062.html
-Advertisement-
Play Games

本地事務 事務類型 事務可以分為本地事務和分散式事務兩種類型。這兩種事務類型是根據訪問並更新的數據資源的多少來進行區分的。本地事務是在單個數據源上進行數據的訪問和更新,而分散式事務是跨越多個數據源來進行數據的訪問和更新。在這裡要說的事務是基於資料庫這種數據源的。 JDBC事務 在JAVA中,我們使用 ...


本地事務

事務類型

事務可以分為本地事務和分散式事務兩種類型。這兩種事務類型是根據訪問並更新的數據資源的多少來進行區分的。本地事務是在單個數據源上進行數據的訪問和更新,而分散式事務是跨越多個數據源來進行數據的訪問和更新。在這裡要說的事務是基於資料庫這種數據源的。

JDBC事務

JAVA中,我們使用JDBC來連接資料庫,訪問和更新數據。那麼在JDBC中是如何實現事務的,事務是被誰來管理的?這個答案當然是資料庫,JDBC本身並沒有處理事務的能力,而是依賴於底層資料庫,底層資料庫來提供事務的服務。在很多資料上會提到,JDBC的事務是基於連接的,也就是那個Connection對象,這個連接的本質其實是連接到資料庫的一個Socket,與資料庫建立連接以後就可以向資料庫發送指令和數據,最終資料庫會根據接收到的指令和數據來進行增刪改查以及事務的處理。另外,事務是被限制在單個連接上的,這就好像我們去銀行的營業廳辦理業務,營業廳有多個視窗,我們只會在自己的視窗上與銀行工作人員進行溝通並處理自身的業務,而不能跨視窗,告訴別的視窗的工作人員把那哥們的錢轉到自己卡上,這事也就只能想想。

 

資料庫事務例子

 

下麵先看一個MYSQL資料庫事務的例子:

 

1、創建表

創建用戶表

CREATE TABLE USERS
(
    USER_ID INT NOT NULL AUTO_INCREMENT  COMMENT '自增主鍵',
    USER_NAME VARCHAR(25) NOT NULL  COMMENT '用戶名',
    PASSWORD  VARCHAR(25) NOT NULL COMMENT '密碼',
    GENDER    VARCHAR(1)  COMMENT '性別',
    PHONE_NO VARCHAR(11) NOT NULL COMMENT '手機號',
        CREATE_TIME DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP() COMMENT '創建時間',
    PRIMARY KEY (USER_ID)
)
COMMENT = '用戶表';

創建用戶和角色的關聯關係表

CREATE TABLE USER_ROLE_RELATION
(
    REL_ID INT NOT NULL AUTO_INCREMENT COMMENT '自增主鍵',
    USER_ID INT NOT NULL COMMENT '用戶ID',
    ROLE_ID INT NOT NULL COMMENT '角色ID',
    PRIMARY KEY (REL_ID)
)
COMMENT = '用戶和角色對應關係表'

2、創建存儲過程,在存儲過程中使用事務

BEGIN
    #聲明一個標誌位,預設為0
    DECLARE T_ERROR INTEGER DEFAULT 0;
    #如果事務執行過程中出現異常,那麼把標誌位設置為1
    DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET T_ERROR = 1;  
    #開始事務
    START TRANSACTION; 
INSERT INTO USERS (USER_NAME, PASSWORD, GENDER, PHONE_NO) VALUES ('zhangsan', '123456', '', '11111111111'); INSERT INTO USER_ROLE_RELATION (USER_ID, ROLE_ID) VALUES ('333', '1'); #如果執行成功,直接提交,否則回滾 IF T_ERROR = 0 THEN COMMIT; ELSE   ROLLBACK; END IF; END

3、執行存儲過程

存儲過程執行成功以後,資料庫的這兩個表中會分別出現一條記錄。然後把

INSERT INTO USER_ROLE_RELATION (USER_ID, ROLE_ID) VALUES ('333', '1');

這個語句改為:

#這條INSERT語句違反了非空約束,會拋出異常
INSERT INTO USER_ROLE_RELATION (USER_ID, ROLE_ID) VALUES (NULL, '1');

重新保存並執行存儲過程,結果是兩個表中都沒有新增記錄。兩條SQL語句要麼同時成功,要麼同時失敗。

 

JDBC事務例子

 

JDBC中如果需要手動提交事務的話,需要用到Connection對象中的三個方法:

 

//設置是否自動提交
setAutoCommit()
//提交
commit()
//回滾
rollback()

 

JDBC中事務的提交方式預設是自動提交的,手動提交的事務的話需要更改預設設置:

 

Connection.setAutoCommit(false)

 

下麵這個例子是假設新增一個用戶並給用戶賦預設許可權,那麼需要同時向兩張表中分別插入一條記錄,把新增用戶和賦許可權看做是一個執行單元,放在一個事務中。

package person.lb.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;


public class TestJDBCTransAction {

    static {
        try {
            //載入驅動類
            Class.forName("com.mysql.jdbc.Driver");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } 
    }
    
    public static void main(String[] args) {
        //執行事務
        executeTransaction();
    }

    private static void executeTransaction() {
        Connection conn = null;
        Statement st1 = null;
        Statement st2 = null;
        ResultSet rs = null;
        try {
            //獲取資料庫連接
            conn = (Connection) DriverManager.getConnection(
                    "jdbc:mysql://192.168.0.105:3306/TEST", 
                    "root", 
                    "root");
            conn.setAutoCommit(false);
            
            st1 = (Statement) conn.createStatement();
            st2 = (Statement) conn.createStatement();
            //插入用戶信息
            st1.execute("INSERT INTO USERS (USER_NAME, PASSWORD, GENDER, PHONE_NO) "
                      + "VALUES ('zhangsan', '123456', '男', '11111111111')"
                      , Statement.RETURN_GENERATED_KEYS);
            //獲取增長列的新值
            rs = st1.getGeneratedKeys();
            String userID = "";
            if(rs.next()) {
                userID = rs.getString(1);
            }
            //插入用戶和角色關聯數據
            st2.execute("INSERT INTO USER_ROLE_RELATION (USER_ID, ROLE_ID) VALUES (" +userID +", '1')");
            conn.commit();
        } catch (SQLException e) {
            e.printStackTrace();
            try {
                conn.rollback();
            } catch (SQLException e1) {
                e1.printStackTrace();
            }
        } finally {
            try {
                if(rs != null) {
                    rs.close();
                }
                if(st1 != null) {
                    st1.close();
                }
                if(st2 != null) {
                    st2.close();
                }
                if(conn != null) {
                    conn.close();
                }
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }
}

程式執行結果如下:

USERS

USER_ROLE_RELATION

 

 

到這裡,JAVA的本地事務算是寫完了。

 

 

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • ...
  • 1.開發IDE:Spring Tool Suite(自帶maven插件) 下載地址https://spring.io/tools/sts/all 在STS.ini配置信息中加下麵一行 保證編碼格式為utf-8 -Dfile.encoding=UTF-8 2.jdk:java 1.8 下載地址http... ...
  • php構造函數是對象創建完成後,第一個自動調用的方法,析構函數是當對象被釋放之前最後一個自動調用的方法。本文章向碼農介紹php構造函數與析構函數。 php構造函數 1.是對象創建完成後,“第一個”“自動調用”的方法 2.構造方法的定義,方法名是一個固定的, 在php4中:和類名相同的方法就是構造方法 ...
  • ...
  • 前幾天看了開源的XML文件解析器TinyXml,它是怎麼實現解析的沒怎麼看懂,於是決定自己實現一個,反正最近不忙。先命名為TXml。現在完成瞭解析和查詢功能,全部代碼加起來不到1000行,將會繼續完善它。源碼必共用 先簡單說一下我的思路: 1:讀取XML文件信息,並存入一個字元數組中; 2:遍曆數組 ...
  • 常見的狀態碼以及其含義 一些常見HTTP狀態碼為: 200 -- 伺服器成功返回網頁 400 -- 伺服器不理解請求的語法 404 -- 請求的網頁不存在 503 -- 服務不可用 常見HTTP狀態碼大全 1xx(臨時響應):表示臨時響應並需要請求者繼續執行操作的狀態代碼。 http狀態碼 100( ...
  • 一.為什麼要使用介面 假如有一個需求:要求實現防盜門的功能。門有"開"和"關"的功能,鎖有"上鎖"和"開鎖"的功能。 分析:首先防盜門是一個門,門有開門和關門的功能,還有一把鎖,鎖有開鎖和上鎖,按照面向對象的編程的思想,我們會將門和鎖都作為一個類而單獨存在,但是,不能讓防盜門繼承自門的同時又繼承自鎖 ...
  • static靜態,作為修飾符,最初是由c引入,一開始static表示退出一個塊後依然存在的局部變數。隨後,static表示不能被其他文件訪問的全局變數和函數。到了C++和java,static表示屬於類且不屬於類對象的變數和函數。 從具體用法來看,主要用到5個方面。 一、靜態域。 static修飾類 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...