1、什麼是Java事務
#通常觀念認為,交易與資料庫有關。事務是存取資料庫的操作序列,資料庫應用系統(tǒng)透過事務集來完成對資料庫的存取。事務的正確執(zhí)行使得資料庫從一種狀態(tài)轉(zhuǎn)換成另一種狀態(tài)。
事務必須服從ISO/IEC所訂定的ACID原則。
ACID是原子性(atomicity)、一致性(consistency)、隔離性(isolation)和持久性(durability)的縮寫事務必須服從ISO/IEC所製定的ACID原則。 ACID是原子性(atomicity)、一致性(consistency)、隔離性(isolation)和持久性(durability)的縮寫。
a、原子性?
即不可分割性,事務要麼全部被執(zhí)行,要麼就全部不被執(zhí)行。如果交易的所有子事務全部提交成功,則所有的資料庫操作被提交,資料庫狀??態(tài)發(fā)生轉(zhuǎn)換;如果有子事務失敗,則其他子事務的資料庫操作被回滾,即資料庫回到事務執(zhí)行前的狀態(tài),不會發(fā)生狀態(tài)轉(zhuǎn)換。
b、一致性?
交易的執(zhí)行使得資料庫從一種正確狀態(tài)轉(zhuǎn)換成另一種正確狀態(tài)。
c、隔離性
在交易正確提交之前,不允許把該事務對資料的任何變更提供給任何其他事務,即在事務正確提交之前,它可能的結果不應顯示給任何其他事務。
d、持久性
交易正確提交後,其結果將永久保存在資料庫中,即使在交易提交後有了其他故障,事務的處理結果也會被保存。
既然事務的概念從資料庫而來,那Java事務是什麼?之間有什麼關聯(lián)?
實際上,一個Java應用系統(tǒng),如果操作資料庫,透過JDBC來實現(xiàn)的。那麼增加、修改、刪除都是透過對應方法間接來實現(xiàn)的,事務的控制也隨之轉(zhuǎn)移到Java程式碼中。因此,資料庫操作的事務習慣上就稱為Java事務。
2、為什麼需要交易
簡單一句話:保持資料的一致性。
3、Java事務類型
Java事務的類型有三種:JDBC事務、JTA(Java Transaction API)事務、容器事務。這裡都是最簡單的介紹,最後還會介紹下jdbc事務的使用,其他兩種大家可以自己搜下學習下。
a、JDBC交易
JDBC 交易是用 Connection 物件控制的。 JDBC Connection 介面( java.sql.Connection )提供了兩種事務模式:自動提交和手動提交。 java.sql.Connection 提供了以下控制交易的方法:
public void setAutoCommit(boolean) public boolean getAutoCommit() public void commit() public void rollback()
使用 JDBC 交易界定時,您可以將多個 SQL 語句結合到一個交易中。 JDBC 交易的一個缺點是交易的範圍侷限於一個資料庫連線。一個 JDBC 交易不能跨越多個資料庫。
b、JTA(Java Transaction API)事務
JTA是一種高層的,與實作無關的,與協(xié)定無關的API,應用程式和應用程式伺服器可以使用JTA來存取事務。
JTA允許應用程式執(zhí)行分散式事務處理--在兩個或多個網(wǎng)路電腦資源上存取並且更新數(shù)據(jù),這些數(shù)據(jù)可以分佈在多個資料庫上。 JDBC驅(qū)動程式的JTA支援大大增強了資料存取能力。
如果計畫用 JTA 界定事務,那麼就需要有一個實作 javax.sql.XADataSource 、 javax.sql.XAConnection 和 javax.sql.XAResource 介面的 JDBC 驅(qū)動程式。
一個實作了這些介面的驅(qū)動程式將可以參與 JTA 事務。一個 XADataSource 物件就是一個 XAConnection 物件的工廠。 XAConnections 是參與 JTA 交易的 JDBC 連接,您將需要以應用程式伺服器的管理工具設定 XADataSource 。
J2EE 應用程式以 JNDI 查詢資料來源。一旦應用程式找到了資料來源對象,它就會呼叫 javax.sql.DataSource.getConnection() 以獲得到資料庫的連線。
XA 連線與非 XA 連線不同。一定要記住 XA 連線參與了 JTA 事務。這意味著 XA 連線不支援 JDBC 的自動提交功能。同時,應用程式一定不要對 XA 連線呼叫 java.sql.Connection.commit() 或 java.sql.Connection.rollback() 。
相反,應用程式應該使用 UserTransaction.begin()、 UserTransaction.commit() 和 serTransaction.rollback() 。????
c、容器事務
容器事務主要是J2EE應用伺服器提供的,容器事務大多是基於JTA完成,這是一個基於JNDI的,相當複雜的API實作。相對編碼實作JTA事務管理,我們可以透過EJB容器提供的容器事務管理機制(CMT)完成同一個功能,這項功能由J2EE應用伺服器提供。
這使得我們可以簡單的指定將哪個方法加入事務,一旦指定,容器將負責事務管理任務。這是我們土建的解決方式,因為透過這種方式我們可以將事務代碼排除在邏輯編碼之外,同時將所有困難交給J2EE容器去解決。
使用EJB CMT的另外一個好處就是程序員無需關心JTA API的編碼,不過,理論上我們必須使用EJB。
d、JDBC事務的使用
(1)步驟:
首先,設置事務的提交方式為非自動提交:conn.setAutoCommit(false);接下來,將需要添加事務的代碼放入try,catch塊中。
然后,在try塊內(nèi)添加事務的提交操作,表示操作無異常,提交事務:conn.commit();尤其不要忘記,在catch塊內(nèi)添加回滾事務,表示操作出現(xiàn)異常,撤銷事務:conn.rollback();最后,設置事務提交方式為自動提交:conn.setAutoCommit(true);這樣,通過簡單的幾步,我們就可以完成對事務處理的編寫了。
(2)偽代碼:
con = DriverManager.getConnection(url, user, password); String result = ""; String sql1 = ""; // LAST_INSERT_ID() 獲取剛剛插入的自動遞增的ID String sql2 = ""; int flag; try { con.setAutoCommit(false);// 更改JDBC事務的默認提交方式 pstmt = con.prepareStatement(sql1); flag = pstmt.executeUpdate(); if (flag > 0) { pstmt = con.prepareStatement(sql2); int i = pstmt.executeUpdate(); if (i > 0) { con.commit();//提交JDBC事務 result = "add data success!!"; } else { result = "add data fail!!"; } } else { result = "add data fail!!"; } } catch (SQLException e) { try { con.rollback();//回滾JDBC事務 } 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事務的默認提交方式 } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } return result;
4、三種事務差異
1、JDBC事務控制的局限性在一個數(shù)據(jù)庫連接內(nèi),但是其使用簡單。
2、JTA事務的功能強大,事務可以跨越多個數(shù)據(jù)庫或多個DAO,使用也比較復雜。
3、容器事務,主要指的是J2EE應用服務器提供的事務管理,局限于EJB應用使用。
5、總結
事務控制是構建J2EE應用不可缺少的一部分,合理選擇應用何種事務對整個應用系統(tǒng)來說至關重要。一般說來,在單個JDBC 連接連接的情況下可以選擇JDBC事務,在跨多個連接或者數(shù)據(jù)庫情況下,需要選擇使用JTA事務,如果用到了EJB,則可以考慮使用EJB容器事務。
更多相關知識請關注java基礎教程欄目
以上是JAVA中的事務處理的詳細內(nèi)容。更多資訊請關注PHP中文網(wǎng)其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

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

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

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發(fā)環(huán)境

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

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

寫好PHP註釋的關鍵在於明確目的與規(guī)範,註釋應解釋“為什麼”而非“做了什麼”,避免冗餘或過於簡單。 1.使用統(tǒng)一格式,如docblock(/*/)用於類、方法說明,提升可讀性與工具兼容性;2.強調(diào)邏輯背後的原因,如說明為何需手動輸出JS跳轉(zhuǎn);3.在復雜代碼前添加總覽性說明,分步驟描述流程,幫助理解整體思路;4.合理使用TODO和FIXME標記待辦事項與問題,便於後續(xù)追蹤與協(xié)作。好的註釋能降低溝通成本,提升代碼維護效率。

註釋不能馬虎是因為它要解釋代碼存在的原因而非功能,例如兼容老接口或第三方限制,否則看代碼的人只能靠猜。必須加註釋的地方包括複雜的條件判斷、特殊的錯誤處理邏輯、臨時繞過的限制。寫註釋更實用的方法是根據(jù)場景選擇單行註釋或塊註釋,函數(shù)、類、文件開頭用文檔塊註釋說明參數(shù)與返回值,並保持註釋更新,對複雜邏輯可在前面加一行概括整體意圖,同時不要用註釋封存代碼而應使用版本控制工具。

寫好註釋的關鍵在於說明“為什麼”而非僅“做了什麼”,提升代碼可讀性。 1.註釋應解釋邏輯原因,例如值選擇或處理方式背後的考量;2.對複雜邏輯使用段落式註釋,概括函數(shù)或算法的整體思路;3.定期維護註釋確保與代碼一致,避免誤導,必要時刪除過時內(nèi)容;4.在審查代碼時同步檢查註釋,並通過文檔記錄公共邏輯以減少代碼註釋負擔。

寫好PHP註釋的關鍵在於清晰、有用且簡潔。 1.註釋應說明代碼背後的意圖而非僅描述代碼本身,如解釋複雜條件判斷的邏輯目的;2.在魔術值、舊代碼兼容、API接口等關鍵場景添加註釋以提升可讀性;3.避免重複代碼內(nèi)容,保持簡潔具體,並使用標準格式如PHPDoc;4.註釋需與代碼同步更新,確保準確性。好的註釋應站在他人角度思考,降低理解成本,成為代碼的理解導航儀。

第一步選擇集成環(huán)境包XAMPP或MAMP搭建本地服務器;第二步根據(jù)項目需求選擇合適的PHP版本並配置多版本切換;第三步選用VSCode或PhpStorm作為編輯器並搭配Xdebug進行調(diào)試;此外還需安裝Composer、PHP_CodeSniffer、PHPUnit等工具輔助開發(fā)。

PHP註釋有三種常用方式:單行註釋適合簡要說明代碼邏輯,如//或#用於當前行解釋;多行註釋/*...*/適合詳細描述函數(shù)或類的作用;文檔註釋DocBlock以/**開頭,為IDE提供提示信息。使用時應避免廢話、保持同步更新,並勿長期用註釋屏蔽代碼。

PHP比較運算符需注意類型轉(zhuǎn)換問題。 1.使用==僅比較值,會進行類型轉(zhuǎn)換,如1=="1"為true;2.使用===需值與類型均相同,如1==="1"為false;3.大小比較可作用於數(shù)值和字符串,如"apple"

寫好PHP註釋的關鍵在於解釋“為什麼”而非“做什麼”,統(tǒng)一團隊註釋風格,避免重複代碼式註釋,合理使用TODO和FIXME標記。 1.註釋應重點說明代碼背後的邏輯原因,如性能優(yōu)化、算法選擇等;2.團隊需統(tǒng)一註釋規(guī)範,如單行註釋用//,函數(shù)類用docblock格式,並包含@author、@since等標籤;3.避免僅複述代碼內(nèi)容的無意義註釋,應補充業(yè)務含義;4.使用TODO和FIXME標記待辦事項,並可配合工具追蹤,確保註釋與代碼同步更新,提升項目可維護性。
