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