Spring中事務配置以及事務不起作用可能出現的問題
前言:在Spring中可以通過對方法進行事務的配置,而不是像原來通過手動寫代碼的方式實現事務的操作,這在很大程度上減少了開發的難度,本文介紹Spring事務配置的兩種方式:基於設定檔的方式和基於註解的方式。並對配置過程中可能出現的問題作出總結。
一、基於設定檔的方式,具體如下:
<context:component-scan base-package="com.learning"/>
<!-- c3p0串連池配置--><!--注意最好是加上編碼的設定,並注意在xml檔案中&需要進行轉義,通過&進行轉義-->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close"
p:driverClass="com.mysql.jdbc.Driver"
p:jdbcUrl="jdbc:mysql://localhost:3306/springlearning?useUnicode=true&characterEncoding=UTF-8"
p:user="root"
p:password=""/>
<!-- 配置jdbcTemplate模板-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"
p:dataSource-ref="dataSource"/>
<!-- 事務配置 3步,比較固定,注意資料庫的引擎,是否支援事務-->
<!--MySql預設資料引擎為MyISAM,是不支援事務,需改成InnoDB才能進行事務的操作-->
<!-- 1.配置事務,開啟spring的交易管理-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
p:dataSource-ref="dataSource"/>
<!-- 2.然後配置事務的增強-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<!-- 做事務操作-->
<tx:attributes>
<!-- 設定進行事務操作的方法匹配規則,就是對什麼方法進行事務操作,這裡可以直接寫方法名,也可以直接寫*,表示對所有方法開啟事務支援-->
<tx:method name="*"/>
</tx:attributes>
</tx:advice>
<!-- 3.然後配置切面-->
<aop:config>
<!-- 切入點--> <!--service包下,所有類中的所有方法都設定為切入點-->
<aop:pointcut id="servicePointcut" expression="execution(* com.learning.service..*(..))"/>
<!-- 切面-->
<aop:advisor advice-ref="txAdvice" pointcut-ref="servicePointcut"/>
</aop:config>
註:設定檔中,對相應步驟都有詳細說明,主要分三步:1.配置交易管理;2.配置事務增強;3.進行切面配置。
二、基於設定檔的方式
<!-- 開啟註解掃描-->
<context:component-scan base-package="com.learning"/>
<!-- c3p0串連池配置-->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close"
p:driverClass="com.mysql.jdbc.Driver"
p:jdbcUrl="jdbc:mysql://localhost:3306/springlearning?useUnicode=true&characterEncoding=UTF-8"
p:user="root"
p:password=""/>
<!-- 配置jdbcTemplate模板-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"
p:dataSource-ref="dataSource"/>
<!--基於註解的方式,在設定檔中只需兩步-->
<!-- 1.配置事務,開啟spring的交易管理-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
p:dataSource-ref="dataSource"/>
<!--2.開啟事務註解掃描-->
<tx:annotation-driven transaction-manager="transactionManager"/>
註:基於註解的方式,在設定檔中只需兩步:1.配置交易管理員(不管是基於設定檔方式或者註解方式,這一步都是必須的);2.開啟事務註解掃描;3.在需要進行事務操作方法的類名上添加註解@Transactional通過以上3個步驟即可完成方式事務的開啟,注意不要忘了在所需開啟事務方法的類上添加註解哦。
Spring事務配置不起作用可能出現的問題:
1.是否是資料庫引擎設定不對造成的【筆者就遇到了這個問題,由於筆者使用的是mysql資料,但是在建立表的時候引擎預設(mysql中引擎預設為MyISAM,是不支援事務操作的),需要修改為InnoDB,就可以支援事務操作了】
2.入口函數必須是public,否則事務不起作用。這一點由Spring的AOP特性決定的。
這就是筆者在配置事務過程中所遇到的問題,如再遇任何問題,則繼續補充。