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

