国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java基礎(chǔ) JAVA中的事務(wù)處理

JAVA中的事務(wù)處理

Jun 16, 2020 pm 04:12 PM
java

JAVA中的事務(wù)處理

1、什麼是Java事務(wù)

#通常觀念認為,交易與資料庫有關(guān)。事務(wù)是存取資料庫的操作序列,資料庫應(yīng)用系統(tǒng)透過事務(wù)集來完成對資料庫的存取。事務(wù)的正確執(zhí)行使得資料庫從一種狀態(tài)轉(zhuǎn)換成另一種狀態(tài)。

事務(wù)必須服從ISO/IEC所訂定的ACID原則。

ACID是原子性(atomicity)、一致性(consistency)、隔離性(isolation)和持久性(durability)的縮寫事務(wù)必須服從ISO/IEC所製定的ACID原則。 ACID是原子性(atomicity)、一致性(consistency)、隔離性(isolation)和持久性(durability)的縮寫。

a、原子性?

即不可分割性,事務(wù)要麼全部被執(zhí)行,要麼就全部不被執(zhí)行。如果交易的所有子事務(wù)全部提交成功,則所有的資料庫操作被提交,資料庫狀??態(tài)發(fā)生轉(zhuǎn)換;如果有子事務(wù)失敗,則其他子事務(wù)的資料庫操作被回滾,即資料庫回到事務(wù)執(zhí)行前的狀態(tài),不會發(fā)生狀態(tài)轉(zhuǎn)換。

b、一致性?

交易的執(zhí)行使得資料庫從一種正確狀態(tài)轉(zhuǎn)換成另一種正確狀態(tài)。

c、隔離性

在交易正確提交之前,不允許把該事務(wù)對資料的任何變更提供給任何其他事務(wù),即在事務(wù)正確提交之前,它可能的結(jié)果不應(yīng)顯示給任何其他事務(wù)。

d、持久性

交易正確提交後,其結(jié)果將永久保存在資料庫中,即使在交易提交後有了其他故障,事務(wù)的處理結(jié)果也會被保存?! ?/p>

既然事務(wù)的概念從資料庫而來,那Java事務(wù)是什麼?之間有什麼關(guān)聯(lián)?

實際上,一個Java應(yīng)用系統(tǒng),如果操作資料庫,透過JDBC來實現(xiàn)的。那麼增加、修改、刪除都是透過對應(yīng)方法間接來實現(xiàn)的,事務(wù)的控制也隨之轉(zhuǎn)移到Java程式碼中。因此,資料庫操作的事務(wù)習慣上就稱為Java事務(wù)。

2、為什麼需要交易

簡單一句話:保持資料的一致性。

3、Java事務(wù)類型

Java事務(wù)的類型有三種:JDBC事務(wù)、JTA(Java Transaction API)事務(wù)、容器事務(wù)。這裡都是最簡單的介紹,最後還會介紹下jdbc事務(wù)的使用,其他兩種大家可以自己搜下學習下。

a、JDBC交易

JDBC 交易是用 Connection 物件控制的。 JDBC Connection 介面( java.sql.Connection )提供了兩種事務(wù)模式:自動提交和手動提交。 java.sql.Connection 提供了以下控制交易的方法:

 public void setAutoCommit(boolean)
 public boolean getAutoCommit()
 public void commit()
 public void rollback()

使用 JDBC 交易界定時,您可以將多個 SQL 語句結(jié)合到一個交易中。 JDBC 交易的一個缺點是交易的範圍侷限於一個資料庫連線。一個 JDBC 交易不能跨越多個資料庫。

b、JTA(Java Transaction API)事務(wù)

JTA是一種高層的,與實作無關(guān)的,與協(xié)定無關(guān)的API,應(yīng)用程式和應(yīng)用程式伺服器可以使用JTA來存取事務(wù)。

JTA允許應(yīng)用程式執(zhí)行分散式事務(wù)處理--在兩個或多個網(wǎng)路電腦資源上存取並且更新數(shù)據(jù),這些數(shù)據(jù)可以分佈在多個資料庫上。 JDBC驅(qū)動程式的JTA支援大大增強了資料存取能力。

如果計畫用 JTA 界定事務(wù),那麼就需要有一個實作 javax.sql.XADataSource 、 javax.sql.XAConnection 和 javax.sql.XAResource 介面的 JDBC 驅(qū)動程式。

一個實作了這些介面的驅(qū)動程式將可以參與 JTA 事務(wù)。一個 XADataSource 物件就是一個 XAConnection 物件的工廠。 XAConnections 是參與 JTA 交易的 JDBC 連接,您將需要以應(yīng)用程式伺服器的管理工具設(shè)定 XADataSource 。

J2EE 應(yīng)用程式以 JNDI 查詢資料來源。一旦應(yīng)用程式找到了資料來源對象,它就會呼叫 javax.sql.DataSource.getConnection() 以獲得到資料庫的連線。

XA 連線與非 XA 連線不同。一定要記住 XA 連線參與了 JTA 事務(wù)。這意味著 XA 連線不支援 JDBC 的自動提交功能。同時,應(yīng)用程式一定不要對 XA 連線呼叫 java.sql.Connection.commit() 或 java.sql.Connection.rollback() 。

相反,應(yīng)用程式應(yīng)該使用 UserTransaction.begin()、 UserTransaction.commit() 和 serTransaction.rollback() 。????

c、容器事務(wù)

容器事務(wù)主要是J2EE應(yīng)用伺服器提供的,容器事務(wù)大多是基於JTA完成,這是一個基於JNDI的,相當複雜的API實作。相對編碼實作JTA事務(wù)管理,我們可以透過EJB容器提供的容器事務(wù)管理機制(CMT)完成同一個功能,這項功能由J2EE應(yīng)用伺服器提供。

這使得我們可以簡單的指定將哪個方法加入事務(wù),一旦指定,容器將負責事務(wù)管理任務(wù)。這是我們土建的解決方式,因為透過這種方式我們可以將事務(wù)代碼排除在邏輯編碼之外,同時將所有困難交給J2EE容器去解決。

使用EJB CMT的另外一個好處就是程序員無需關(guān)心JTA API的編碼,不過,理論上我們必須使用EJB。

d、JDBC事務(wù)的使用

(1)步驟:

首先,設(shè)置事務(wù)的提交方式為非自動提交:conn.setAutoCommit(false);接下來,將需要添加事務(wù)的代碼放入try,catch塊中。

然后,在try塊內(nèi)添加事務(wù)的提交操作,表示操作無異常,提交事務(wù):conn.commit();尤其不要忘記,在catch塊內(nèi)添加回滾事務(wù),表示操作出現(xiàn)異常,撤銷事務(wù):conn.rollback();最后,設(shè)置事務(wù)提交方式為自動提交:conn.setAutoCommit(true);這樣,通過簡單的幾步,我們就可以完成對事務(wù)處理的編寫了。

(2)偽代碼:

con = DriverManager.getConnection(url, user, password);
String result = "";
String sql1 = "";
// LAST_INSERT_ID() 獲取剛剛插入的自動遞增的ID
String sql2 = "";
int flag;
try {
    con.setAutoCommit(false);// 更改JDBC事務(wù)的默認提交方式
    pstmt = con.prepareStatement(sql1);
    flag = pstmt.executeUpdate();
    if (flag > 0) {
        pstmt = con.prepareStatement(sql2);
        int i = pstmt.executeUpdate();
        if (i > 0) {
            con.commit();//提交JDBC事務(wù)
            result = "add data success!!";
        } else {
            result = "add data fail!!";
       }
    } else {
        result = "add data fail!!";
    }
} catch (SQLException e) {
    try {
        con.rollback();//回滾JDBC事務(wù)
    } catch (SQLException e1) {
    // TODO Auto-generated catch block
        result = "add data fail!! SQLException";
        e1.printStackTrace();
    }
    result = "add data fail!! SQLException";
    e.printStackTrace();
} finally {
    try {
        con.setAutoCommit(true); // 恢復JDBC事務(wù)的默認提交方式
    } catch (SQLException e) {
    // TODO Auto-generated catch block
        e.printStackTrace();
    }
}
return result;

4、三種事務(wù)差異

1、JDBC事務(wù)控制的局限性在一個數(shù)據(jù)庫連接內(nèi),但是其使用簡單。

2、JTA事務(wù)的功能強大,事務(wù)可以跨越多個數(shù)據(jù)庫或多個DAO,使用也比較復雜。

3、容器事務(wù),主要指的是J2EE應(yīng)用服務(wù)器提供的事務(wù)管理,局限于EJB應(yīng)用使用。

5、總結(jié)

事務(wù)控制是構(gòu)建J2EE應(yīng)用不可缺少的一部分,合理選擇應(yīng)用何種事務(wù)對整個應(yīng)用系統(tǒng)來說至關(guān)重要。一般說來,在單個JDBC 連接連接的情況下可以選擇JDBC事務(wù),在跨多個連接或者數(shù)據(jù)庫情況下,需要選擇使用JTA事務(wù),如果用到了EJB,則可以考慮使用EJB容器事務(wù)。

更多相關(guān)知識請關(guān)注java基礎(chǔ)教程欄目

以上是JAVA中的事務(wù)處理的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔相應(yīng)的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
VSCODE設(shè)置。 JSON位置 VSCODE設(shè)置。 JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位於用戶級或工作區(qū)級路徑,用於自定義VSCode設(shè)置。 1.用戶級路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級路徑:項目根目錄下的.vscode/settings

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動提交模式,再執(zhí)行多個操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點實現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

Python Itertools組合示例 Python Itertools組合示例 Jul 31, 2025 am 09:53 AM

itertools.combinations用於生成從可迭代對像中選取指定數(shù)量元素的所有不重複組合(順序無關(guān)),其用法包括:1.從列表中選2個元素組合,如('A','B')、('A','C')等,避免重複順序;2.對字符串取3個字符組合,如"abc"、"abd",適用於子序列生成;3.求兩數(shù)之和等於目標值的組合,如1 5=6,簡化雙重循環(huán)邏輯;組合與排列的區(qū)別在於順序是否重要,combinations視AB與BA為相同,而permutations視為不同;

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

Python Pytest夾具示例 Python Pytest夾具示例 Jul 31, 2025 am 09:35 AM

fixture是用於為測試提供預設(shè)環(huán)境或數(shù)據(jù)的函數(shù),1.使用@pytest.fixture裝飾器定義fixture;2.在測試函數(shù)中以參數(shù)形式註入fixture;3.yield之前執(zhí)行setup,之後執(zhí)行teardown;4.通過scope參數(shù)控製作用域,如function、module等;5.將共用fixture放在conftest.py中實現(xiàn)跨文件共享,從而提升測試的可維護性和復用性。

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當前日期時間;3.使用of()方法創(chuàng)建特定日期時間;4.利用plus/minus方法不可變地增減時間;5.使用ZonedDateTime和ZoneId處理時區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

了解Java虛擬機(JVM)內(nèi)部 了解Java虛擬機(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

故障排除常見的java`ofmemoryError`場景'' 故障排除常見的java`ofmemoryError`場景'' Jul 31, 2025 am 09:07 AM

java.lang.OutOfMemoryError:Javaheapspace表示堆內(nèi)存不足,需檢查大對象處理、內(nèi)存洩漏及堆設(shè)置,通過堆轉(zhuǎn)儲分析工具定位並優(yōu)化代碼;2.Metaspace錯誤因類元數(shù)據(jù)過多,常見於動態(tài)類生成或熱部署,應(yīng)限制MaxMetaspaceSize並優(yōu)化類加載;3.Unabletocreatenewnativethread因係統(tǒng)線程資源耗盡,需檢查線程數(shù)限制、使用線程池、調(diào)整棧大??;4.GCoverheadlimitexceeded指GC頻繁但回收少,應(yīng)分析GC日誌,優(yōu)化

See all articles