Spring的事务配置详解

Spring的事务配置详解

配置DataSource

  1. 先从jdbc.properties加载参数
<!-- 加载jdbc.properties文件 -->
<context:property-placeholder location="classpath:jdbc.properties" />

    <!-- 配置连接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
    <property name="driverClass" value="${jdbc.driverClass}"></property>
    <property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
    <property name="user" value="${jdbc.user}"></property>
    <property name="password" value="${jdbc.password}"></property>
</bean>
  1. 配置事务核心管理器

    • 事务核心管理器是依赖于DataSource的
<!-- 配置事务核心管理器,封装了所有的事务操作,依赖于连接池 -->
<bean id="transactionManager"
    class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"></property>
</bean>
  1. 配置事务通知和织入通知

    • tx:method:配置事务方法属性,说明:

    • name:要增强的方法的名称规则,

      • 可以使用通配符,表示以trans开始的方法都加上事务
    • isolation:配置事务隔离级别,默认值DEFAULT。

      • 实际项目中使用默认值即可
    • propagation:配置事务传播行为。默认值REQUIRED,

      • 一般增/删/改方法使用REQUIRED;查询使用:SUPPORTS
    • timeout:配置事务的超时。

      • -1是默认值,表示永不超时。实际项目中,使用默认值即可
    • read-only:配置是否是只读事务,取值true/false,

      • 一般查询使用true;增/删/改使用false
    • no-rollback-for:指定发生某个异常时,不回滚,其它异常回滚。

      • 没有默认值,所有异常都不回滚
    • rollback-for:指定发生某个异常,就回滚,其它异常 不回滚。

      • 没有默认值,所有异常都回滚
<!-- 配置事务通知 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
    <!-- 配置事务的属性 -->
    <tx:attributes>
        <!--tx:method:配置事务方法属性,说明:
            name:要增强的方法的名称规则,可以使用通配符*,表示以trans开始的方法都加上事务
            isolation:配置事务隔离级别,默认值DEFAULT。实际项目中使用默认值即可
            propagation:配置事务传播行为。默认值REQUIRED,一般增/删/改方法使用REQUIRED;查询使用:SUPPORTS
            timeout:配置事务的超时。-1是默认值,表示永不超时。实际项目中,使用默认值即可
            read-only:配置是否是只读事务,取值true/false,一般查询使用true;增/删/改使用false
            no-rollback-for:指定发生某个异常时,不回滚,其它异常回滚。没有默认值,所有异常都不回滚
            rollback-for:指定发生某个异常,就回滚,其它异常 不回滚。没有默认值,所有异常都回滚
          -->
        <tx:method name="transfer" isolation="DEFAULT" propagation="REQUIRED" read-only="false" />
    </tx:attributes>
</tx:advice>

<!-- 配置织入 -->
<aop:config>
    <aop:pointcut expression="execution( * com.service.impl.*ServiceImpl.*(..))" id="txpc"/>

    <!-- 建立事务管理器对象,与切入点表达式的关系 -->
    <aop:advisor advice-ref="txAdvice" pointcut-ref="txpc"/>
</aop:config>

总配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd ">

    <!-- 加载jdbc.properties文件 -->
    <context:property-placeholder location="classpath:jdbc.properties" />

    <!-- 配置事务核心管理器,封装了所有的事务操作,依赖于连接池 -->
    <bean id="transactionManager"
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>


    <!-- 配置事务通知 -->
    <tx:advice id="txAdvice" transaction-manager="transactionManager" >
    <tx:attributes>

        <!--tx:method:配置事务方法属性,说明:
            name:要增强的方法的名称规则,可以使用通配符*,表示以trans开始的方法都加上事务
            isolation:配置事务隔离级别,默认值DEFAULT。实际项目中使用默认值即可
            propagation:配置事务传播行为。默认值REQUIRED,一般增/删/改方法使用REQUIRED;查询使用:SUPPORTS
            timeout:配置事务的超时。-1是默认值,表示永不超时。实际项目中,使用默认值即可
            read-only:配置是否是只读事务,取值true/false,一般查询使用true;增/删/改使用false
            no-rollback-for:指定发生某个异常时,不回滚,其它异常回滚。没有默认值,所有异常都不回滚
            rollback-for:指定发生某个异常,就回滚,其它异常 不回滚。没有默认值,所有异常都回滚
          -->
        <tx:method name="save*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
        <tx:method name="persist*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
        <tx:method name="update*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
        <tx:method name="modify*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
        <tx:method name="delete*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
        <tx:method name="remove*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
        <tx:method name="get*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="true" />
        <tx:method name="find*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="true" />
        <tx:method name="transfer" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
    </tx:attributes>
</tx:advice>

    <!-- 配置织入 -->
    <aop:config>
        <aop:pointcut expression="execution( * com.service.impl.*ServiceImpl.*(..))" id="txpc"/>

        <!-- 建立事务管理器对象,与切入点表达式的关系 -->
        <aop:advisor advice-ref="txAdvice" pointcut-ref="txpc"/>
    </aop:config>



    <bean id="accountServiceImpl" class="com.service.impl.AccountServiceImpl">
        <property name="ac" ref="accountDaoImpl"></property>
    </bean>

    <bean id="accountDaoImpl" class="com.dao.impl.AccountDaoImpl">
        <property name="jt" ref="jdbcTemplate"></property>
    </bean>

    <!-- 配置模板对象 -->
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <property name="dataSource" ref="dataSource"></property>
    </bean>


    <!-- 配置连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${jdbc.driverClass}"></property>
        <property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
        <property name="user" value="${jdbc.user}"></property>
        <property name="password" value="${jdbc.password}"></property>
    </bean>

</beans>

猜你喜欢

转载自blog.csdn.net/kato_op/article/details/80247829