Spring中事務配置以及事務不起作用可能出現的問題

來源:互聯網
上載者:User

Spring中事務配置以及事務不起作用可能出現的問題

前言:在Spring中可以通過對方法進行事務的配置,而不是像原來通過手動寫代碼的方式實現事務的操作,這在很大程度上減少了開發的難度,本文介紹Spring事務配置的兩種方式:基於設定檔的方式和基於註解的方式。並對配置過程中可能出現的問題作出總結。

一、基於設定檔的方式,具體如下:

<context:component-scan base-package="com.learning"/>

    <!-- c3p0串連池配置--><!--注意最好是加上編碼的設定,並注意在xml檔案中&需要進行轉義,通過&amp;進行轉義-->
    <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&amp;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&amp;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特性決定的。

這就是筆者在配置事務過程中所遇到的問題,如再遇任何問題,則繼續補充。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.