• Spring、Spring事务详解;使用XML配置事务


    @Transactional可以设置以下参数:

    @Transactional(readOnly=false)  // 指定事务是否只读的 true/false
    @Transactional(rollbackFor=Exception.class)  //指定在什么异常情况下回滚事务,默认在运行时异常回滚(RuntimeException),Exception异常不回滚
    @Transactional(noRollbackFor=Exception.class) //指定在什么异常情况下不回滚事务 ,默认在运行时异常回滚(RuntimeException),Exception异常不回滚
    @Transactional(noRollbackForClassName="Exception") // 同@Transactional(noRollbackFor=Exception.class) 
    @Transactional(rollbackForClassName="Exception") // 同@Transactional(noRollbackFor=Exception.class)
    @Transactional(timeout=30000) //设置事务超时时间,默认30秒
    @Transactional(propagation=Propagation.NOT_SUPPORTED) //不使用事务;propagation设置事务的传播特性,具体看下面
    @Transactional(isolation=Isolation.REPEATABLE_READ) //数据库事务隔离级别

    Propagation 详解:


    Isolation详解:



    使用XML配置事务:

    <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    		<property name="dataSource" ref="dataSource" />
    	</bean>
    	
    	<tx:advice id="txAdvice" transaction-manager="txManager">
    		<tx:attributes>
    			<tx:method name="get*" propagation="NOT_SUPPORTED" />
    			<tx:method name="save*" propagation="REQUIRED" rollback-for="Exception"/>
    		    <tx:method name="del*" propagation="REQUIRED" rollback-for="Exception" />
    		    <!-- ... -->
    		</tx:attributes>
    	</tx:advice>
    	
    	<!--  配置参与事务的类 -->
    	<aop:config>
    		<aop:pointcut id="transcationPointcut" expression="execution(* cn.service.impl.*.*(..))"/>
    		<aop:advisor pointcut-ref="transcationPointcut" advice-ref="txAdvice" />
    	</aop:config>


    注: 使用注解的方式配置事务,更加的方便,可扩展性更高,推荐使用注解的方式配置事务。

  • 相关阅读:
    vim的使用
    linux 环境下,kafka_2.123.0.0 集群搭建
    NetCore3.1 ping网络是否畅通及获取服务器Cpu、内存使用率
    使用kafkatool连接使用Kafka
    NetCore3.1 制作windows服务
    kafka_2.123.0.0 版本Topic、producer 命令记录
    NetCore 控制台应用程序依赖注入
    使用 contentvisibility 优化渲染性能
    有意思的鼠标指针交互探究
    linux中如何将多条命令写入在一行中,其中包括while语句,同时,在k8s的command中如何来使用
  • 原文地址:https://www.cnblogs.com/raphael5200/p/5114733.html
Copyright © 2020-2023  润新知