溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring中事務控制的示例分析

發(fā)布時間:2021-07-24 10:12:10 來源:億速云 閱讀:89 作者:小新 欄目:編程語言

這篇文章主要介紹Spring中事務控制的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

1.事務的概念

事務是一組操作的執(zhí)行單元,相對于數(shù)據(jù)庫的單條操作而言,事務管理的是一組SQL指令,如增刪改查等,事務的特性體現(xiàn)在事務內包含的SQL指令必須全部執(zhí)行成功,如果其中一條指令發(fā)生錯誤,那么整個事務內的一組操作都要進行回滾。

事務有四個特性:

  • 原子性 Atomic ,事務是一個不可再拆分的最小單位,要么整個執(zhí)行,要么整個回滾.

  • 一致性 Consistent,事務要保證數(shù)據(jù)庫整體數(shù)據(jù)的完整性和業(yè)務的數(shù)據(jù)的一致性,事務成功提交整體數(shù)據(jù)修改,事務錯誤則回滾到數(shù)據(jù)回到原來的狀態(tài)。

  • 隔離性 Isolate,兩個事務的執(zhí)行都是獨立的,事務之前不會相互影響,多個事務操作一個對象時會以串行等待的方式保證事務相互之間處于隔離。

  • 持久性 Durable,一旦事務成功提交后,數(shù)據(jù)將會保存到數(shù)據(jù)庫,不能再進行回滾,以后的操作都將在當前數(shù)據(jù)庫狀態(tài)上繼續(xù)進行。

2.Spring中的事務控制方式

編程式事務管理

通過手動編碼控制事務的邊界,可以實現(xiàn)細粒度的事務控制,一般用的較少。

聲明式事務管理

只需要在Spring中添加一些配置文件或者使用注解,即可實現(xiàn)將操作納入事務管理中,事務管理使用了Spring AOP,降低了代碼之間的耦合。

3.事務管理器

Spring中并沒有直接管理事務,而是將管理事務委托給相應的持久化機制提供的某個特定平臺的實現(xiàn)。

事務管理器實現(xiàn)目標
org.springframework.jdbc.datasource.DataSourceTransactionManager在單一的JDBC Datasource中管理事務
org.springframework.orm.hibernate5.HibernateTransactionManager當持久化機制是hibernate時,用它來管理事務
org.springframework.jdo.JdoTransactionManager當持久化機制是Jdo時,用它來管理事務
org.springframework.transaction.jta.JtaTransactionManager使用一個JTA實現(xiàn)來管理事務。在一個事務跨越多個資源時必須使用
org.springframework.orm.ojb.PersistenceBrokerTransactionManager當apache的ojb用作持久化機制時,用它來管理事務

4.事務屬性簡介

Spring關于事務的注解中有以下幾個屬性(部分)

@Transactional(
readOnly = false, //讀寫事務
timeout = -1, //超時
noRollbackFor = ArithmeticException.class //遇到數(shù)學異常不回滾
isolation = Isolation.REPEATABLE_READ, //事務隔離級別
propagation = Propagation.REQUIRED //事務傳播規(guī)則
)
  • 是否為只讀事務:只讀事務不做任何修改,可以優(yōu)化查詢操作。

  • 事務超時(單位為秒):事務的最長持續(xù)時間,如果該時間內事務一直沒有操作或回滾,則系統(tǒng)將自動進行回滾。-1表示不超時,但最終實現(xiàn)需要由底層數(shù)據(jù)庫實現(xiàn)。

  • 隔離級別:控制并發(fā)訪問下數(shù)據(jù)庫的安全性。

  • 傳播規(guī)則:定義事務方法和調用事務方法的方法之間的事務邊界。

5.事務傳播規(guī)則

傳播行為意義
REQUIRED業(yè)務方法需要在一個事務中運行。如果方法運行時,已經處在一個事務中,那么加入到該事務,否則為自己創(chuàng)建一個新的事務
NOT_SUPPORTED聲明方法不需要事務。如果方法沒有關聯(lián)到一個事務,容器不會為它開啟事務。如果方法在一個事務中被調用,該事務會被掛起,在方法調用結束后,原先的事務便會恢復執(zhí)行
REQUIRES_NEW屬性表明不管是否存在事務,業(yè)務方法總會為自己發(fā)起一個新的事務。如果方法已經運行在一個事務中,則原有事務會被掛起,新的事務會被創(chuàng)建,直到方法執(zhí)行結束,新事務才算結束,原先的事務才會恢復執(zhí)行
MANDATORY該屬性指定業(yè)務方法只能在一個已經存在的事務中執(zhí)行,業(yè)務方法不能發(fā)起自己的事務。如果業(yè)務方法在沒有事務的環(huán)境下調用,容器就會拋出異常
SUPPORTS這一事務屬性表明,如果業(yè)務方法在某個事務范圍內被調用,則方法成為該事務的一部分。如果業(yè)務方法在事務范圍外被調用,則方法在沒有事務的環(huán)境下執(zhí)行
NEVER指定業(yè)務方法絕對不能在事務范圍內執(zhí)行。如果業(yè)務方法在某個事務中執(zhí)行,容器會拋出異常,只有業(yè)務方法沒有關聯(lián)到任何事務,才能正常執(zhí)行
NESTED如果一個活動的事務存在,則運行在一個嵌套的事務中. 如果沒有活動事務, 則按REQUIRED屬性執(zhí)行.它使用了一個單獨的事務, 這個事務擁有多個可以回滾的保存點。內部事務的回滾不會對外部事務造成影響。它只對DataSourceTransactionManager事務管理器起效

6.事務隔離級別

隔離級別意義
DEFAULT默認的隔離級別
READ_UNCOMMITED允許你讀取還未提交的改變了的數(shù)據(jù)??赡軐е屡K、幻、不可重復讀
READ_COMMITTED允許在并發(fā)事務已經提交后讀取??煞乐古K讀,但幻讀和 不可重復讀仍可發(fā)生
REPEATABLE_READ對相同字段的多次讀取是一致的,除非數(shù)據(jù)被事務本身改變??煞乐古K、不可重復讀,但幻讀仍可能發(fā)生
SERIALIZABLE完全服從事務ACID的隔離級別,確保不發(fā)生臟、幻、不可重復讀。這在所有的隔離級別中是最慢的,它是典型的通過完全鎖定在事務中涉及的數(shù)據(jù)表來完成的
  • 不同的隔離級別采用不同的方式來實現(xiàn),在四種隔離級別中,Serializable的隔離級別最高,Read Uncommited的隔離級別最低。

  • 大多數(shù)據(jù)庫默認的隔離級別為Read Commited,如SqlServer,Oracle

  • 當然也有少部分數(shù)據(jù)庫默認的隔離級別為Repeatable_Read ,如Mysql,

  • Oracle數(shù)據(jù)庫支持READ COMMITTED和SERIALIZABLE兩種事務隔離性級別,不支持READ UNCOMMITTED和REPEATABLE READ這兩種隔離性級別。雖然SQL標準定義的默認事務隔離性級別是SERIALIZABLE,但是Oracle數(shù)據(jù)庫默認使用的事務隔離性級別卻是READ COMMITTED.

以上是“Spring中事務控制的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI