亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring事務傳播屬性和隔離級別詳細介紹

 更新時間:2017年09月26日 11:59:06   作者:煮海焚天  
這篇文章主要介紹了Spring事務傳播屬性和隔離級別詳細介紹,同時涉及傳播行為介紹,超時設置等相關內容,需要的朋友可以參考下。

1 事務的傳播屬性(Propagation)

1) REQUIRED ,這個是默認的屬性

Support a current transaction, create a new one if none exists.

如果存在一個事務,則支持當前事務。如果沒有事務則開啟一個新的事務。

被設置成這個級別時,會為每一個被調用的方法創(chuàng)建一個邏輯事務域。如果前面的方法已經創(chuàng)建了事務,那么后面的方法支持當前的事務,如果當前沒有事務會重新建立事務。  

2) MANDATORY

Support a current transaction, throw an exception if none exists.支持當前事務,如果當前沒有事務,就拋出異常。

3) NEVER

Execute non-transactionally, throw an exception if a transaction exists.

以非事務方式執(zhí)行,如果當前存在事務,則拋出異常。

4) NOT_SUPPORTED

Execute non-transactionally, suspend the current transaction if one exists.

以非事務方式執(zhí)行操作,如果當前存在事務,就把當前事務掛起。

5) REQUIRES_NEW

Create a new transaction, suspend the current transaction if one exists.

新建事務,如果當前存在事務,把當前事務掛起。

6) SUPPORTS

Support a current transaction, execute non-transactionally if none exists.

支持當前事務,如果當前沒有事務,就以非事務方式執(zhí)行。

7) NESTED

Execute within a nested transaction if a current transaction exists, behave like PROPAGATION_REQUIRED else.

支持當前事務,新增Savepoint點,與當前事務同步提交或回滾。

嵌套事務一個非常重要的概念就是內層事務依賴于外層事務。外層事務失敗時,會回滾內層事務所做的動作。而內層事務操作

失敗并不會引起外層事務的回滾。

8) PROPAGATION_NESTED 與PROPAGATION_REQUIRES_NEW的區(qū)別

它們非常 類似,都像一個嵌套事務,如果不存在一個活動的事務,都會開啟一個新的事務。使用PROPAGATION_REQUIRES_NEW時,內層事務與外層事務就像兩個獨立的事務一樣,一旦內層事務進行了提交后,外層事務不能對其進行回滾。兩個事務互不影響。兩個事務不是一個真正的嵌套事務。同時它需要JTA 事務管理器的支持。

使用PROPAGATION_NESTED時,外層事務的回滾可以引起內層事務的回滾。而內層事務的異常并不會導致外層事務的回滾,它是一個真正的嵌套事務。

2 事務的隔離級別(Isolation Level)

1) 首先說明一下事務并發(fā)引起的三種情況

i. Dirty Reads 臟讀

一個事務正在對數(shù)據(jù)進行更新操作,但是更新還未提交,另一個事務這時也來操作這組數(shù)據(jù),并且讀取了前一個事務還未提交的數(shù)據(jù),而前一個事務如果操作失敗進行了回滾,后一個事務讀取的就是錯誤數(shù)據(jù),這樣就造成了臟讀。

ii. Non-Repeatable Reads 不可重復讀

一個事務多次讀取同一數(shù)據(jù),在該事務還未結束時,另一個事務也對該數(shù)據(jù)進行了操作,而且在第一個事務兩次次讀取之間,第二個事務對數(shù)據(jù)進行了更新,那么第一個事務前后兩次讀取到的數(shù)據(jù)是不同的,這樣就造成了不可重復讀。

iii. Phantom Reads 幻像讀

第一個數(shù)據(jù)正在查詢符合某一條件的數(shù)據(jù),這時,另一個事務又插入了一條符合條件的數(shù)據(jù),第一個事務在第二次查詢符合同一條件的數(shù)據(jù)時,發(fā)現(xiàn)多了一條前一次查詢時沒有的數(shù)據(jù),仿佛幻覺一樣,這就是幻像讀。

iv. 非重復度和幻像讀的區(qū)別

非重復讀是指同一查詢在同一事務中多次進行,由于其他提交事務所做的修改或刪除,每次返回不同的結果集,此時發(fā)生非重復讀。(A transaction rereads data it has previously read and finds that another committed transaction has modified or deleted the data. )

幻像讀是指同一查詢在同一事務中多次進行,由于其他提交事務所做的插入操作,每次返回不同的結果集,此時發(fā)生幻像讀。(A transaction reexecutes a query returning a set of rows that satisfies a search condition and finds that another committed transaction has inserted additional rows that satisfy the condition. )

表面上看,區(qū)別就在于非重復讀能看見其他事務提交的修改和刪除,而幻像能看見其他事務提交的插入。

2) DEFAULT (默認)

這是一個PlatfromTransactionManager默認的隔離級別,使用數(shù)據(jù)庫默認的事務隔離級別.另外四個與JDBC的隔離級別相對應

3) READ_UNCOMMITTED (讀未提交)

這是事務最低的隔離級別,它允許另外一個事務可以看到這個事務未提交的數(shù)據(jù)。這種隔離級別會產生臟讀,不可重復讀和幻像讀。

4) READ_COMMITTED (讀已提交)

保證一個事務修改的數(shù)據(jù)提交后才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的數(shù)據(jù)。這種事務隔離級別可以避免臟讀出現(xiàn),但是可能會出現(xiàn)不可重復讀和幻像讀。

5) REPEATABLE_READ (可重復讀)

這種事務隔離級別可以防止臟讀,不可重復讀。但是可能出現(xiàn)幻像讀。它除了保證一個事務不能讀取另一個事務未提交的數(shù)據(jù)外,還保證了不可重復讀

6) SERIALIZABLE(串行化)

這是花費最高代價但是最可靠的事務隔離級別。事務被處理為順序執(zhí)行。除了防止臟讀,不可重復讀外,還避免了幻像讀。

7) 隔離級別解決事務并行引起的問題

Dirty reads non-repeatable reads phantom reads

Serializable 不會 不會 不會

REPEATABLE READ 不會 不會 會

READ COMMITTED 不會 會 會

Read Uncommitted 會 會 會

事物傳播行為介紹:

@Transactional(propagation=Propagation.REQUIRED)

如果有事務, 那么加入事務, 沒有的話新建一個(默認情況下)

@Transactional(propagation=Propagation.NOT_SUPPORTED)

容器不為這個方法開啟事務

@Transactional(propagation=Propagation.REQUIRES_NEW)

不管是否存在事務,都創(chuàng)建一個新的事務,原來的掛起,新的執(zhí)行完畢,繼續(xù)執(zhí)行老的事務

@Transactional(propagation=Propagation.MANDATORY)

必須在一個已有的事務中執(zhí)行,否則拋出異常

@Transactional(propagation=Propagation.NEVER)

必須在一個沒有的事務中執(zhí)行,否則拋出異常(與Propagation.MANDATORY相反)

@Transactional(propagation=Propagation.SUPPORTS)

如果其他bean調用這個方法,在其他bean中聲明事務,那就用事務.如果其他bean沒有聲明事務,那就不用事務.

事物超時設置:

@Transactional(timeout=30) //默認是30秒

事務隔離級別:

@Transactional(isolation = Isolation.READ_UNCOMMITTED)

讀取未提交數(shù)據(jù)(會出現(xiàn)臟讀, 不可重復讀) 基本不使用

@Transactional(isolation = Isolation.READ_COMMITTED)

讀取已提交數(shù)據(jù)(會出現(xiàn)不可重復讀和幻讀)

@Transactional(isolation = Isolation.REPEATABLE_READ)

可重復讀(會出現(xiàn)幻讀)

@Transactional(isolation = Isolation.SERIALIZABLE)

串行化

MYSQL: 默認為REPEATABLE_READ級別

SQLSERVER: 默認為READ_COMMITTED

臟讀 : 一個事務讀取到另一事務未提交的更新數(shù)據(jù)

不可重復讀 : 在同一事務中, 多次讀取同一數(shù)據(jù)返回的結果有所不同, 換句話說,

后續(xù)讀取可以讀到另一事務已提交的更新數(shù)據(jù). 相反, "可重復讀"在同一事務中多次

讀取數(shù)據(jù)時, 能夠保證所讀數(shù)據(jù)一樣, 也就是后續(xù)讀取不能讀到另一事務已提交的更新數(shù)據(jù)

幻讀 : 一個事務讀到另一個事務已提交的insert數(shù)據(jù)

關于嵌套事物

可能大家對PROPAGATION_NESTED還不怎么了解,覺得有必要再補充一下^_^!

PROPAGATION_NESTED: 嵌套事務類型,是相對上面提到的六種情況(上面的六種應該稱為平面事務類型),打個比方我現(xiàn)在有一個事務主要有一下幾部分:

     1,從A用戶帳戶里面減去100元錢

      2,往B用戶帳戶里面添加100元錢

       這樣看和以前不同的事務可能沒有什么區(qū)別,那我現(xiàn)在有點特殊的要求就是,A用戶有3個帳戶,B用戶有2個帳戶,現(xiàn)在我的要求就是只要再A用戶的3個帳戶里面任意一個減去100元,往B用戶的兩個帳戶中任意一個里面增加100元就可以了!

       一旦你有這樣的要求那嵌套事務類型就非常適合你!我們可以這樣理解,

       一:將“從A用戶帳戶里面減去100元錢” 和 “往B用戶帳戶里面增加100元錢”我們暫時認為是一級事務操作

       二:將從A用戶的3個帳戶的任意一個帳戶里面減錢看做是“從A用戶帳戶里面減去100元錢”這個一級事務的子事務(二級事務),同樣把后面存錢的看成是另一個的二級事務。

      問題一:當二級事務被rollback一級事務會不會被rollback?

      答案是不會的,二級事務的rollback只針對自己。

      問題二:什么時候這個一級事務會commit,什么時候會被rollback呢?

      我們主要看二級里面出現(xiàn)的情況,當所有的二級事務被commit了并且一級事務沒有失敗的操作,那整個事務就算是一個成功的事務,這種情況整個事務會被commit。

當任意一個二級事務沒有被commit那整個事務就是失敗的,整個事務會被roolback。

還是拿上面的例子來說明吧!如果我在a的三個帳戶里面減錢的操作都被二級事務給rollback了,也就是3個帳戶里面都沒有減錢成功,整個事務就失敗了就會被rollback。如果A用戶帳戶三個帳戶里面有一個可以扣錢而且B用戶的兩個帳戶里面也有一個帳戶可以增加錢,那整個事務就算成功的,會被 commit。

看了一下覺得上面的例子好像不是很深刻,看這個情況(A用戶的3個帳戶都是有信用額度的,也就是說可以超支,但是超支有金額限制)。不過原理是一樣的,簡單點也好說明一點,祝你好運!^_^

總結

以上就是本文關于Spring事務傳播屬性和隔離級別詳細介紹的全部內容,希望對大家有所幫助。感興趣的朋友可以瀏覽本站的其他專題。有問題請留言,小編會及時回復大家的。

相關文章

  • Java文件復制多種方法實例代碼

    Java文件復制多種方法實例代碼

    近期用到文件復制,雖然程序很簡單,因為時間久了淡忘了,所以寫一篇文章記錄一下,下面這篇文章主要給大家介紹了關于Java文件復制多種方法的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • 如何實現(xiàn)Java中一個簡單的LinkedList

    如何實現(xiàn)Java中一個簡單的LinkedList

    LinkedList與ArrayList都是List接口的具體實現(xiàn)類。下面將介紹如何實現(xiàn)一個簡單的LinkedList,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • Struts2中ognl遍歷數(shù)組,list和map方法詳解

    Struts2中ognl遍歷數(shù)組,list和map方法詳解

    這篇文章主要介紹了Struts2中ognl遍歷數(shù)組,list和map方法詳解,需要的朋友可以參考下。
    2017-09-09
  • Mybatis中多個對象包含同一個對象的處理操作

    Mybatis中多個對象包含同一個對象的處理操作

    這篇文章主要介紹了Mybatis中多個對象包含同一個對象的處理操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java實現(xiàn)HTTPS連接的示例代碼

    Java實現(xiàn)HTTPS連接的示例代碼

    現(xiàn)在的網絡世界,安全性是大家都非常關注的問題,特別是對于咱們這些程序員來說,所以,理解并實現(xiàn)HTTPS連接,對于保護咱們的數(shù)據(jù)安全是極其重要的,下面我們就來學習一下在Java中如何實現(xiàn)HTTPS連接吧
    2023-12-12
  • 用Java進行zip文件壓縮與解壓縮

    用Java進行zip文件壓縮與解壓縮

    這篇文章主要介紹了用Java進行zip文件壓縮與解壓縮的方法,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-12-12
  • 詳解RocketMQ中的消費者啟動與消費流程分析

    詳解RocketMQ中的消費者啟動與消費流程分析

    本文主要介紹了RocketMQ的消費者啟動流程,結合官方源碼和示例,一步步講述消費者在啟動和消息消費中的的工作原理及內容,并結合平時業(yè)務工作中,對我們所熟悉的順序、push/pull模式等進行詳細分析,以及對于消息消費失敗和重投帶來問題去進行分析,需要的朋友可以參考下
    2022-07-07
  • Java中Map接口使用以及有關集合的面試知識點匯總

    Java中Map接口使用以及有關集合的面試知識點匯總

    在java面試過程中,Map時常會被作為一個面試點來問,下面這篇文章主要給大家介紹了關于Java中Map接口使用以及有關集合的面試知識點匯總的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 如何使用JWT的SpringSecurity實現(xiàn)前后端分離

    如何使用JWT的SpringSecurity實現(xiàn)前后端分離

    這篇文章主要介紹了使用JWT的SpringSecurity實現(xiàn)前后端分離,登錄成功需要返回json數(shù)據(jù)登錄失敗需要返回json數(shù)據(jù)權限不足時返回json數(shù)據(jù)未登錄訪問資源返回json數(shù)據(jù),需要的朋友可以參考下
    2024-08-08
  • IDEA自動生成TestNG的testng.xml的插件方法

    IDEA自動生成TestNG的testng.xml的插件方法

    這篇文章主要介紹了IDEA自動生成TestNG的testng.xml的插件方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04

最新評論