`

spring声明式事物不起作用的原因

阅读更多
09:41:37,848 [main] INFO  jdbc.connection  - 3. Connection opened  org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
09:41:37,849 [main] DEBUG jdbc.connection  - open connections:  3 (1)
09:41:37,849 [main] DEBUG jdbc.audit  - 3. Connection.new Connection returned   org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
09:41:37,849 [main] DEBUG jdbc.audit  - 3. Connection.getAutoCommit() returned true  org.mybatis.spring.transaction.SpringManagedTransaction.openConnection(SpringManagedTransaction.java:85)
09:41:37,849 [main] DEBUG org.mybatis.spring.transaction.SpringManagedTransaction  - JDBC Connection [net.sf.log4jdbc.ConnectionSpy@20576557] will not be managed by Spring
切入点配置不正确时:

当你的切入点路径配置不正确时(或者你配置的路径与你调用的点不匹配时候)!那么这个切面(spring事物管理器)就不被执行,相应的就不会开启事物等等操作了。而数据源的连接默认是开启自动提交的,就达不到事物了。

当你配置正确后,信息是这样的:
09:53:54,254 [main] DEBUG org.springframework.beans.factory.support.DefaultListableBeanFactory  - Returning cached instance of singleton bean 'empServiceImpl'
09:53:54,257 [main] DEBUG org.springframework.jdbc.datasource.DataSourceTransactionManager  - Creating new transaction with name [com.boat.service.impl.EmpServiceImpl.updateEmpBaseInfo]: PROPAGATION_REQUIRED,ISOLATION_DEFAULT
09:53:54,257 [main] INFO  jdbc.connection  - 3. Connection opened  org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
09:53:54,257 [main] DEBUG jdbc.connection  - open connections:  3 (1)
09:53:54,257 [main] DEBUG jdbc.audit  - 3. Connection.new Connection returned   org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
09:53:54,258 [main] DEBUG org.springframework.jdbc.datasource.DataSourceTransactionManager  - Acquired Connection [net.sf.log4jdbc.ConnectionSpy@360bc645] for JDBC transaction
09:53:54,258 [main] DEBUG jdbc.audit  - 3. Connection.getAutoCommit() returned true  org.springframework.jdbc.datasource.DataSourceTransactionManager.doBegin(DataSourceTransactionManager.java:220)
09:53:54,258 [main] DEBUG org.springframework.jdbc.datasource.DataSourceTransactionManager  - Switching JDBC Connection [net.sf.log4jdbc.ConnectionSpy@360bc645] to manual commit
09:53:54,259 [main] DEBUG jdbc.audit  - 3. Connection.setAutoCommit(false) returned   org.springframework.jdbc.datasource.DataSourceTransactionManager.doBegin(DataSourceTransactionManager.java:225)
09:53:54,260 [main] DEBUG org.springframework.jdbc.datasource.DataSourceTransactionManager  - Participating in existing transaction
09:53:54,277 [main] DEBUG org.mybatis.spring.SqlSessionUtils  - Creating a new SqlSession
09:53:54,287 [main] DEBUG org.mybatis.spring.SqlSessionUtils  - Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@1c7f96b1]
09:53:54,379 [main] DEBUG jdbc.audit  - 3. Connection.getAutoCommit() returned false  org.mybatis.spring.transaction.SpringManagedTransaction.openConnection(SpringManagedTransaction.java:85)
09:53:54,379 [main] DEBUG org.mybatis.spring.transaction.SpringManagedTransaction  - JDBC Connection [net.sf.log4jdbc.ConnectionSpy@360bc645] will be managed by Spring

事物管理器在判断连接是否自动提交后,会将自动提交改为收到提交。并设置事物传播属性及隔离级别等等操作。这在事物管理这个切面处所在的事情。

分享到:
评论

相关推荐

    Spring源代码解析(六):Spring声明式事务处理.doc

    Spring 声明式事务处理 Spring 中的事务处理可以分为两种方式:声明式事务处理和编程式事务处理。声明式事务处理通过 AOP 的实现,把事务管理代码作为方面封装到业务代码中,使得事务管理代码和业务代码解藕。这...

    spring.net 声明式事物管理小示例

    在这个声明式事务管理的小示例中,我们将探讨如何使用 Spring.NET 来实现事务的自动化处理。 1. **什么是声明式事务管理?** 声明式事务管理允许开发者通过配置或注解来定义事务的边界,而不是在代码中显式地调用 ...

    spring编程式事物

    标题"spring编程式事物"主要关注的是编程式事务管理。这种方式允许开发者通过`PlatformTransactionManager`接口和`TransactionDefinition`接口来控制事务的生命周期。在Spring中,通常使用`TransactionTemplate`或者...

    Spring中的声明式事物

    7. **Spring AOP在声明式事务中的作用** - AOP是实现声明式事务的基础,它通过代理模式在方法调用前后插入事务管理代码。 - 事务增强器(如`TransactionInterceptor`)根据配置的事务属性决定是否开始、提交、回滚...

    Spring Boot多数据源(支持Spring声明式事务切换和回滚).pdf

    《Spring Boot多数据源(支持Spring声明式事务切换和回滚)》 Spring Boot多数据源技术是构建高效、灵活的多租户SaaS架构的关键。在本文中,我们将深入探讨如何实现动态数据源切换,支持Spring声明式事务管理,并讨论...

    Spring声明式事务配置模板2.x

    在Spring框架中,声明式事务管理是其核心特性之一,它极大地简化了应用程序中的事务处理。Spring 2.x版本的声明式事务配置模板是开发者常用的一种方式,它通过AOP(面向切面编程)实现事务的自动管理,使得开发者...

    spring中事物配置

    Spring提供了两种事务管理方式:编程式事务管理和声明式事务管理。本篇将重点讲解如何利用AOP(面向切面编程)进行声明式事务配置。 首先,我们需要理解AOP在Spring中的作用。AOP是一种设计模式,它允许我们在不...

    Spring+Hibernate 声明式事务

    本资源主要是结合博文 Spring+Hibernate: 声明式事务 http://blog.csdn.net/ManagementAndJava/article/details/78050519 的源代码,主要是讲解了spring4.3和hibernate5.2.11集成实现原理;

    Spring(IOC,APD,声明式事物的例子)

    让我们深入探讨这些概念以及如何在Spring中实现声明式事务管理。 **1. Inversion of Control (IoC)** IoC,也称为依赖注入(Dependency Injection),是一种设计模式,它将对象的创建和管理权交给了框架,而不是由...

    spring的5中事物配置 介绍spring的5中事物配置

    Spring 框架提供了多种...在选择事务配置方式时,通常建议使用基于注解或XML的声明式事务管理,因为它们更易于维护和扩展。同时,了解每种配置方式的原理和适用场景,可以帮助我们更好地设计和实现应用程序的事务管理。

    第十四章 Spring4 切面事物与事物通知与传播行为

    Spring4提供了两种事务管理方式:编程式事务管理和声明式事务管理。编程式事务管理需要在代码中显式地管理事务开始、提交和回滚,而声明式事务管理则通过在配置或注解中声明事务规则,更加灵活且易于维护。例如,...

    spring-tx事物源码

    Spring的事务管理机制包括编程式事务管理和声明式事务管理,这两种方式都基于`spring-tx`模块。在这个源码中,我们可以深入理解Spring如何处理事务的生命周期、回滚规则以及与各种数据源的集成。 首先,`spring-tx`...

    spring事物和rabbitMQ的例子

    Spring提供了一种声明式事务管理方式,使得开发者可以在不直接编写事务控制代码的情况下,通过配置来管理事务的边界。在"spring的2个数据源的配置"中,这意味着系统可能需要处理来自两个不同数据源的数据,例如一个...

    spring-控制事物回滚

    总结起来,"spring-控制事物回滚"涵盖的知识点包括Spring的声明式事务管理、事务的回滚规则、传播行为、隔离级别以及源码分析和相关工具的使用。理解和掌握这些内容,对于提升Java企业级应用开发的能力至关重要。

    spring-控制事物

    此外,Spring AOP的代理机制(如JDK动态代理或CGLIB代理)在声明式事务管理中的作用也是源码学习的重要部分。 至于“工具”,可能是指一些辅助工具或技术,如IDEA中的debug工具,可以帮助开发者在调试过程中观察...

    spring事物传播测试表

    Spring事务管理有编程式和声明式两种方式。编程式事务管理需要程序员手动控制事务的开始、提交和回滚,而声明式事务管理则通过AOP(面向切面编程)来实现,更易于维护。通常,我们使用后者,因为它更简洁且与业务...

    Spring事物配置的五种模式

    这种方式适用于那些无法使用声明式事务的复杂场景。 **配置示例**: ```java @Service public class UserService { @Autowired private PlatformTransactionManager transactionManager; public void create...

    Spring事务管理Demo

    在Spring框架中,事务管理是核心特性之一,它允许开发者以声明式或编程式的方式处理应用中的事务。Spring事务管理的目的是确保数据的一致性和完整性,尤其是在多操作、多资源的环境中。本Demo将深入探讨Spring如何...

Global site tag (gtag.js) - Google Analytics