SpringAOP事務(wù)配置語法及實(shí)現(xiàn)過程詳解
配置事務(wù): 使用的tx前綴的標(biāo)簽, 導(dǎo)入tx的命名空間
配置事務(wù)管理器 , 把事務(wù)管理器交給Spring管理:
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 注入DataSource -->
<property name="dataSource" ref="dataSource"/>
</bean>
事務(wù)的策略
transaction-manager: 事務(wù)增強(qiáng)基于那個(gè)事務(wù)管理器, 默認(rèn)值: transactionManager(bean的id)
如果事務(wù)管理器的id為transactionManager, 在tx:advice標(biāo)簽中不需要添加transaction-manager屬性
<tx:advice id="txAdvice" transaction-manager="txManager">
<!-- 聲明事務(wù)的規(guī)則 : 針對(duì)業(yè)務(wù)層的不同的方法,采用不同的規(guī)則-->
<tx:attributes>
<tx:method name="find*" read-only="true" propagation="SUPPORTS" />
<tx:method name="query*" read-only="true" propagation="SUPPORTS"/>
<tx:method name="get*" read-only="true" propagation="SUPPORTS"/>
<tx:method name="add*" propagation="REQUIRED" rollback-for="java.lang.Exception"/>
<tx:method name="del*" propagation="REQUIRED" rollback-for="java.lang.Exception" timeout="2"/>
<tx:method name="update*" propagation="REQUIRED" rollback-for="java.lang.Exception"/>
<tx:method name="*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
事務(wù)規(guī)則的語法:
name: 表示業(yè)務(wù)層的方法名
read-only: 只讀, true 查詢中使用這個(gè)屬性, 默認(rèn)值: false
propagation: 事務(wù)傳播機(jī)制:
*** REQUIRED:默認(rèn)值,表示如果存在一個(gè)事務(wù),則支持當(dāng)前事務(wù),如果當(dāng)前沒有事務(wù),則開啟一個(gè)新的事務(wù). 增刪改
*** SUPPORTS:表示如果存在一個(gè)事務(wù),則支持當(dāng)前事務(wù),如果當(dāng)前沒有事務(wù),則按非事務(wù)方式執(zhí)行, 查詢
MANDATORY:表示如果存在一個(gè)事務(wù),則支持當(dāng)前事務(wù),如果當(dāng)前沒有事務(wù),則拋出異常
REQUIRES_NEW:表示總是開啟一個(gè)新的事務(wù),如果當(dāng)前有一個(gè)事務(wù),則將當(dāng)前事務(wù)掛起,開啟新事物執(zhí)行方法.
NOT_SUPPORTED:表示總是以非事務(wù)方式執(zhí)行.如果一個(gè)事務(wù)已經(jīng)存在,則將這個(gè)存在的事務(wù)掛起,然后執(zhí)行方法.
NEVER:表示總是以非事務(wù)方式執(zhí)行.如果當(dāng)前存在一個(gè)活動(dòng)的事務(wù),則拋出異常
NESTED:表示如果當(dāng)前存在一個(gè)活動(dòng)的事務(wù),則創(chuàng)建一個(gè)事務(wù)作為當(dāng)前事務(wù)的嵌套事務(wù)運(yùn)行,如果沒有當(dāng)前事務(wù),該取值與REQUIRED相同.
timeout: 超時(shí), -1 永不超時(shí), 默認(rèn)值, 正整數(shù), 單位秒
rollback-for="異常類型", 針對(duì)哪一種異常類型進(jìn)行回滾, ,默認(rèn)值:RuntimeException
no-rollback-for="異常類型", 不對(duì)哪一種異常類型進(jìn)行回滾
isolation: 事務(wù)隔離級(jí)別: 數(shù)據(jù)庫來決定
DEFAULT:默認(rèn)值,表示使用數(shù)據(jù)庫默認(rèn)的事務(wù)隔離級(jí)別
READ_UNCOMMITTED:讀未提交, 讀取到未提交的數(shù)據(jù), 所有的數(shù)據(jù)庫都不采用
READ_COMMITTED:讀已提交 oracle
REPEATABLE_READ: 可重復(fù)讀 mysql
SERIALIZABLE: 串行讀 安全性最高, 效率最低
timeout: 從執(zhí)行業(yè)務(wù)方法開始,到執(zhí)行完sql語句之間的時(shí)候
事務(wù)的織入 (把這個(gè)事務(wù)的通知對(duì)那些類的那些方法進(jìn)行增強(qiáng))
<!-- 事務(wù)的織入 ,把這個(gè)事務(wù)的通知對(duì)那些類的那些方法進(jìn)行增強(qiáng)-->
<aop:config>
<!-- 切入點(diǎn)-->
<aop:pointcut expression="execution(* spring07.service..*.*(..))" id="pointcut1"/>
<!-- 織入
advice-ref: 通知類的bean
pointcut-ref: 切入點(diǎn)
-->
<aop:advisor advice-ref="txAdvice" pointcut-ref="pointcut1"/>
</aop:config>
臟讀 :一個(gè)事務(wù)讀到了另一個(gè)事務(wù)的未提交的數(shù)據(jù)
不可重復(fù)讀 :一個(gè)事務(wù)讀到了另一個(gè)事務(wù)已經(jīng)提交的 update 的數(shù)據(jù)導(dǎo)致多次查詢結(jié)果不一致
幻讀 :一個(gè)事務(wù)讀到了另一個(gè)事務(wù)已經(jīng)提交的 insert 的數(shù)據(jù)導(dǎo)致多次查詢結(jié)果不一致
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
spring boot jpa寫原生sql報(bào)Cannot resolve table錯(cuò)誤解決方法
在本篇文章里小編給大家整理的是關(guān)于spring boot jpa寫原生sql報(bào)Cannot resolve table錯(cuò)誤的解決方法,需要的朋友學(xué)習(xí)下。2019-11-11
Java集合Map的clear與new Map區(qū)別詳解
這篇文章主要介紹了Java集合Map的clear與new Map區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04
java創(chuàng)建多級(jí)目錄文件的實(shí)例講解
下面小編就為大家分享一篇java創(chuàng)建多級(jí)目錄文件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-01-01
Jdbc的步驟以及簡(jiǎn)單實(shí)現(xiàn)代碼
下面小編就為大家?guī)硪黄狫dbc的步驟以及簡(jiǎn)單實(shí)現(xiàn)代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-07-07
Springboot實(shí)現(xiàn)動(dòng)態(tài)定時(shí)任務(wù)流程詳解
通過重寫SchedulingConfigurer方法實(shí)現(xiàn)對(duì)定時(shí)任務(wù)的操作,單次執(zhí)行、停止、啟動(dòng)三個(gè)主要的基本功能,動(dòng)態(tài)的從數(shù)據(jù)庫中獲取配置的定時(shí)任務(wù)cron信息,通過反射的方式靈活定位到具體的類與方法中2022-09-09
java實(shí)現(xiàn)簡(jiǎn)單猜數(shù)字游戲
這篇文章主要介紹了java實(shí)現(xiàn)簡(jiǎn)單猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12

