- 浏览: 47400 次
- 性别:
- 来自: 深圳
文章分类
最新评论
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
事物管理器在判断连接是否自动提交后,会将自动提交改为收到提交。并设置事物传播属性及隔离级别等等操作。这在事物管理这个切面处所在的事情。
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
事物管理器在判断连接是否自动提交后,会将自动提交改为收到提交。并设置事物传播属性及隔离级别等等操作。这在事物管理这个切面处所在的事情。
发表评论
-
api调用计数限制
2017-10-10 09:56 518import java.util.concurrent.Con ... -
多个key,单个value的缓存实现
2017-09-11 17:58 596假如一条记录可以用id,idcard,name分别唯一的查询到 ... -
java模拟多处理器调度
2017-08-14 10:10 476import java.util.LinkedList; im ... -
java读写锁升级与降级、并会发现死锁。抛出异常
2017-08-10 16:35 981package com.huawei.test; impor ... -
用java代码来定时增量同步数据库表的实现代码
2017-04-20 17:08 11788import java.io.Serializable; im ... -
javac 和 java不同小版本时会报错,最后配置一样
2017-02-24 14:20 2868Information:Using javac 1.8.0_1 ... -
支持分布式的id生成器
2016-11-09 18:00 749import java.util.concurrent.ato ... -
Rabbitmq高可用设计思路
2016-10-14 17:41 2917Rabbitmq高可用设计思路 ... -
rabbitmq实现高吞吐量的rpc调用
2016-10-09 16:21 9313rabbitmq实现rpc调用基本思路: 客户端(client ... -
shiro Ajax请求未登陆响应json串实现
2016-09-18 11:00 3884package com.cc.sec; import jav ... -
md5加密,jdk7 与jdk8对含有中文的明文加密注意
2015-12-29 12:27 1709private static final String ALG ... -
通过修改web.xml让服务器重启的问题
2015-11-26 09:28 928通过修改web.xml让服务器重启的问题? 通过修改web.x ... -
使用java反射机制实现java的深拷贝
2014-09-10 11:32 1392import java.lang.reflect.Constr ...
相关推荐
Spring 声明式事务处理 Spring 中的事务处理可以分为两种方式:声明式事务处理和编程式事务处理。声明式事务处理通过 AOP 的实现,把事务管理代码作为方面封装到业务代码中,使得事务管理代码和业务代码解藕。这...
在这个声明式事务管理的小示例中,我们将探讨如何使用 Spring.NET 来实现事务的自动化处理。 1. **什么是声明式事务管理?** 声明式事务管理允许开发者通过配置或注解来定义事务的边界,而不是在代码中显式地调用 ...
标题"spring编程式事物"主要关注的是编程式事务管理。这种方式允许开发者通过`PlatformTransactionManager`接口和`TransactionDefinition`接口来控制事务的生命周期。在Spring中,通常使用`TransactionTemplate`或者...
7. **Spring AOP在声明式事务中的作用** - AOP是实现声明式事务的基础,它通过代理模式在方法调用前后插入事务管理代码。 - 事务增强器(如`TransactionInterceptor`)根据配置的事务属性决定是否开始、提交、回滚...
《Spring Boot多数据源(支持Spring声明式事务切换和回滚)》 Spring Boot多数据源技术是构建高效、灵活的多租户SaaS架构的关键。在本文中,我们将深入探讨如何实现动态数据源切换,支持Spring声明式事务管理,并讨论...
在Spring框架中,声明式事务管理是其核心特性之一,它极大地简化了应用程序中的事务处理。Spring 2.x版本的声明式事务配置模板是开发者常用的一种方式,它通过AOP(面向切面编程)实现事务的自动管理,使得开发者...
Spring提供了两种事务管理方式:编程式事务管理和声明式事务管理。本篇将重点讲解如何利用AOP(面向切面编程)进行声明式事务配置。 首先,我们需要理解AOP在Spring中的作用。AOP是一种设计模式,它允许我们在不...
本资源主要是结合博文 Spring+Hibernate: 声明式事务 http://blog.csdn.net/ManagementAndJava/article/details/78050519 的源代码,主要是讲解了spring4.3和hibernate5.2.11集成实现原理;
让我们深入探讨这些概念以及如何在Spring中实现声明式事务管理。 **1. Inversion of Control (IoC)** IoC,也称为依赖注入(Dependency Injection),是一种设计模式,它将对象的创建和管理权交给了框架,而不是由...
Spring 框架提供了多种...在选择事务配置方式时,通常建议使用基于注解或XML的声明式事务管理,因为它们更易于维护和扩展。同时,了解每种配置方式的原理和适用场景,可以帮助我们更好地设计和实现应用程序的事务管理。
Spring4提供了两种事务管理方式:编程式事务管理和声明式事务管理。编程式事务管理需要在代码中显式地管理事务开始、提交和回滚,而声明式事务管理则通过在配置或注解中声明事务规则,更加灵活且易于维护。例如,...
Spring的事务管理机制包括编程式事务管理和声明式事务管理,这两种方式都基于`spring-tx`模块。在这个源码中,我们可以深入理解Spring如何处理事务的生命周期、回滚规则以及与各种数据源的集成。 首先,`spring-tx`...
Spring提供了一种声明式事务管理方式,使得开发者可以在不直接编写事务控制代码的情况下,通过配置来管理事务的边界。在"spring的2个数据源的配置"中,这意味着系统可能需要处理来自两个不同数据源的数据,例如一个...
总结起来,"spring-控制事物回滚"涵盖的知识点包括Spring的声明式事务管理、事务的回滚规则、传播行为、隔离级别以及源码分析和相关工具的使用。理解和掌握这些内容,对于提升Java企业级应用开发的能力至关重要。
此外,Spring AOP的代理机制(如JDK动态代理或CGLIB代理)在声明式事务管理中的作用也是源码学习的重要部分。 至于“工具”,可能是指一些辅助工具或技术,如IDEA中的debug工具,可以帮助开发者在调试过程中观察...
Spring事务管理有编程式和声明式两种方式。编程式事务管理需要程序员手动控制事务的开始、提交和回滚,而声明式事务管理则通过AOP(面向切面编程)来实现,更易于维护。通常,我们使用后者,因为它更简洁且与业务...
这种方式适用于那些无法使用声明式事务的复杂场景。 **配置示例**: ```java @Service public class UserService { @Autowired private PlatformTransactionManager transactionManager; public void create...
在Spring框架中,事务管理是核心特性之一,它允许开发者以声明式或编程式的方式处理应用中的事务。Spring事务管理的目的是确保数据的一致性和完整性,尤其是在多操作、多资源的环境中。本Demo将深入探讨Spring如何...
"Spring声明式事务@Transactional知识点分享" 在 Spring 框架中,@Transactional 注解是实现声明式事务的关键。通过 @Transactional 注解,可以指定事务的传播行为、隔离级别、读写控制等属性。 首先,@...