一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - SpringMVC+MyBatis聲明式事務管理

SpringMVC+MyBatis聲明式事務管理

2020-01-03 14:27hebedich JAVA教程

在最近的一個項目中,采用springMVC、mybatis,MySQL、tomcat,事務管理對于企業應用來說是至關重要的,即使出現異常情況,它也可以保證數據的一致性。Spring Framework對事務管理提供了一致的抽象,

采用的基本搭建環境:SpringMVC、MyBatis、MySQL、tomcat
        Spring事務管理分解了傳統的全局事務管理和本地事務管理的劣勢,使得在任何環境中都可以使用統一的事務管理模型,你可以寫一次代碼,然后在不同的環境從你的代碼里面配置不同的事務管理策略,Spring提供兩種事務管理策略:一種是聲明式事務管理策略,另一種是編程式事務管理策略,這里主要介紹聲明式事務管理策略
由于采用的是SpringMVC、 MyBatis,故統一采用了標注來聲明Service、Controller
由于服務器啟動時的加載配置文件的順序為web.xml---root-context.xml(Spring的配置文件)---servlet-context.xml(SpringMVC的配置文件),由于root-context.xml配置文件中Controller會先進行掃描裝配,但是此時service還沒有進行事務增強處理,得到的將是原樣的Service(沒有經過事務加強處理,故而沒有事務處理能力),所以我們必須在root-context.xml中不掃描Controller,配置如下:
?
1
2
3
4
5
6
7
8
<!-- 自動掃描組件,這里要把controler下面的 controller去除,他們是在spring3-servlet.xml中配置的,如果不去除會影響事務管理的。  -->
 <context:component-scan base-package="com.sence">
 <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" /> 
 .</context:component-scan>
 <!-- 自動掃描組件,這里要把controler下面的 controller去除,他們是在spring3-servlet.xml中配置的,如果不去除會影響事務管理的。  -->
 <context:component-scan base-package="com.sence">
 <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />
 </context:component-scan>
在servlet-context.xml中掃描Controller同時不掃描Service,配置如下:
 
?
1
2
3
4
5
6
7
8
9
10
<!-- 掃描所有的controller 但是不掃描service-->
 <context:component-scan base-package="com.sence">
 <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
 <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
 </context:component-scan>
 <!-- 掃描所有的controller 但是不掃描service-->
 <context:component-scan base-package="com.sence">
 <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
 <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
 </context:component-scan>
下面就可以進行配置聲明式事務管理了,配置如下:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<!-- transaction manager, use DataSourceTransactionManager -->
 <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
 <property name="dataSource" ref="dataSource" />
 </bean>
 <!-- spring declarative transaction management -->
 <aop:config>
 <aop:pointcut id="fooServiceMethods"
 expression="execution(* com.sence.*.service.impl.*.*(..))"/> 
 <aop:advisor advice-ref="txAdvice" pointcut-ref="fooServiceMethods"/> 
 </aop:config>
 <tx:advice id="txAdvice" transaction-manager="txManager">
 <tx:attributes>
 <tx:method name="find*" read-only="true"/>
 <tx:method name="load*" read-only="true"/>
 <tx:method name="*" rollback-for="CustomException"/>
 </tx:attributes>
 </tx:advice>
 <!-- transaction manager, use DataSourceTransactionManager -->
 <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
 <property name="dataSource" ref="dataSource" />
 </bean>
 <!-- spring declarative transaction management -->
<aop:config>
 <aop:pointcut id="fooServiceMethods"
 expression="execution(* com.sence.*.service.impl.*.*(..))"/>
 <aop:advisor advice-ref="txAdvice" pointcut-ref="fooServiceMethods"/>
 </aop:config>
 <tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
 <tx:method name="find*" read-only="true"/>
 <tx:method name="load*" read-only="true"/>
 <tx:method name="*" rollback-for="CustomException"/>
 </tx:attributes>
 </tx:advice>
到此我的配置完成了,但是經過我的測試,當我往MySQL數據庫表批量增加對象時,當其中一個對象出現錯誤,拋出CustomException事務卻不回滾,這個真是令人頭疼,于是我繼續查找,步驟如下:
1. 查找是否聲明式事務管理有誤,如切入點寫錯了
2. 查找Controller掃描部分配置是否正確
但是這兩點我都查了,還是事務沒有回滾,這個時候我沒辦法了,只能動用終極武器了:查看源碼,開始debug程序,發現進入到了事務,并且出現了異常,捕獲后進入到了回滾程序,但是數據庫卻沒有回滾,為了避免Spring自己的AbstractPlatformTransactionManager的干擾,我自己定制了一個事務管理類并繼承配置文件中的DataSourceTransactionManager類,這樣可以清楚的看到程序的運行軌跡,繼續DEBUG,還是出現了異常,捕獲后進入到了回滾程序,但是數據庫卻沒有回滾,此刻我開始懷疑MySQL數據庫的事務支持功能了,于是網上查找MySQL對事務的支持,發現MySQL4.0以后可以支持事務,但是MySql的數據表分為兩類,一類是傳統的數據表,另一類則是支持事務的數據表。支持事務的數據表分為兩種:InnoDB和BerkeleyDB
使用一下命令:show create table ***  查看我的數據庫表的屬性才發現我的表原來是傳統類型的表,于是我使用navicat更改了表的類型為:InnoDB,然后運行程序發現事務回滾了
到此SpringMVC聲明式事務管理配置完成,并運行正確

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 77成人影视| 免费观看视频高清在线 | 婷婷久久综合 | caoporen在线视频入口 | 欧美视频一级 | 色综合 成人 | 99久久99久久免费精品蜜桃 | 九九热综合 | 亚洲日韩精品欧美一区二区 | 亚洲网站在线看 | 精品精品国产自在香蕉网 | 涩色爱 | 我半夜摸妺妺的奶C了她软件 | 久久久久激情免费观看 | 国产欧美日韩一区二区三区在线 | 国产日产精品久久久久快鸭 | 欧美区视频 | 荡女人人爱全文免费阅读 | 国亚洲欧美日韩精品 | 热99re国产久热在线 | 波多野结衣178部中文字幕 | 国产一级片在线 | 满城尽带黄金甲大胸片 | 欧美18-19 | 精品一区二区三区波多野结衣 | 99这里只有精品在线 | 亚洲精品成人在线 | 欧美人做人爱a全程免费 | 国产一区视频在线免费观看 | 清纯漂亮女友初尝性过程 | 成人免费视频大全 | 日本乱人伦中文在线播放 | 国产高清好大好夹受不了了 | 国产欧美日韩成人 | 小鸟酱视频在线观看 | 4虎tv| 国产裸舞福利资源在线视频 | 午夜影院小视频 | h版小说 | 色综合视频一区二区观看 | 精品一区二区三区高清免费不卡 |