ssm事务、spring+ibatis+junit调用存储过程事务不提交解决方法、测试类事务不提交解决方法

94 篇文章 0 订阅
60 篇文章 2 订阅

参考:http://blog.csdn.net/molingduzun123/article/details/49383235

问题:spring+ibatis+junit调用存储过程,事务不提交(rolled back)、ssm事务不提交解决方法。


遇到打印日志如下,在用junit进行单元测试时,调用sql server库的存储过程,会报如下问题,即事务自动回滚:

 (1) 明明已经插入了数据,但是却没有提交到数据库中:

(2)spring+ibatis+junit遇到无法提交到数据库问题:

[java] view plain copy
  1. 10:44:56.682 [main] WARN  - Unable to proxy method [public final void org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests.setApplicationContext(org.springframework.context.ApplicationContext)] because it is final: All calls to this method via a proxy will NOT be routed to the target instance.  
  2. 10:44:56.777 [main] INFO  - Began transaction (1for test context [DefaultTestContext@54b07eeb testClass = DeviceControllerTest, testInstance = com.tonson.app.push.api.user.DeviceControllerTest@f5ca1bd, testMethod = testClientSetting@DeviceControllerTest, testException = [], mergedContextConfiguration = [MergedContextConfiguration@a7e872c testClass = DeviceControllerTest, locations = '{classpath:spring/applicationContext.xml}', classes = '{}', contextInitializerClasses = '[]', activeProfiles = '{}', contextLoader = 'org.springframework.test.context.support.DelegatingSmartContextLoader', parent = []]]; transaction manager [org.springframework.jdbc.datasource.DataSourceTransactionManager@78dc5f15]; rollback [true]  
  3. 10:44:56.793 [main] DEBUG - {conn-100000} Connection  
  4. 10:44:56.820 [main] DEBUG - {conn-100000} Preparing Call: {call UP_UserConfig_Save1 (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)}  
  5. 10:44:56.846 [main] DEBUG - {pstm-100001} Executing Statement: {call UP_UserConfig_Save1 (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)}  
  6. 10:44:56.846 [main] DEBUG - {pstm-100001} Parameters: [011111121110111118151445111]  
  7. 10:44:56.847 [main] DEBUG - {pstm-100001} Types: [java.lang.Integer, java.lang.String, java.lang.String, java.lang.Integer, java.lang.String, java.lang.Integer, java.lang.Integer, java.lang.Integer, java.lang.Integer, java.lang.Integer, java.lang.Integer, java.lang.String]  
  8. {"lan":false,"message":"成功","returncode":0}  
  9. 10:44:56.984 [main] INFO  - Rolled back transaction after test execution for test context [DefaultTestContext@54b07eeb testClass = DeviceControllerTest, testInstance = com.autohome.app.push.api.user.DeviceControllerTest@f5ca1bd, testMethod = testClientSetting@DeviceControllerTest, testException = [], mergedContextConfiguration = [MergedContextConfiguration@a7e872c testClass = DeviceControllerTest, locations = '{classpath:spring/applicationContext.xml}', classes = '{}', contextInitializerClasses = '[]', activeProfiles = '{}', contextLoader = 'org.springframework.test.context.support.DelegatingSmartContextLoader', parent = []]]  
  10. 10:44:56.988 [Thread-1] INFO  - Closing org.springframework.context.support.GenericApplicationContext@79ed3030: startup date [Sat Oct 24 10:44:54 CST 2015]; root of context hierarchy  

如果此时测试的本意是要更新库里数据,则需要在对应测试的方法上加注解:@Rollback(false),如:

加上了这句以后则可以正常地在测试类提交信息到数据库中了。

[java] view plain copy
  1. @Test  
  2. @Rollback(false)//防止事务自动回滚  
  3. public void testClientSetting(){  
  4. }  
当然,在使用事务相关注解时,需要声明式事务,即在applicationContext.xml文件中添加:

[html] view plain copy
  1. <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="false" />  
  2.        
  3. <!-- 定义事务 -->  
  4. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
  5.     <property name="dataSource" ref="pushApiDataSource" />  
  6. </bean>  

正常运行如图:




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 基于SSMSpring+SpringMVC+MyBatis)的管理系统是一种常见的Web应用程序,它使用Spring框架作为应用程序的核心,SpringMVC框架作为Web层的控制器,MyBatis框架作为数据访问层的ORM框架。这种管理系统可以用于各种企业级应用程序,例如人力资源管理系统、客户关系管理系统、库存管理系统等。它具有易于扩展、高效、安全等优点,是现代企业信息化建设的重要组成部分。 ### 回答2: SSM是指基于SpringSpringMVC和MyBatis这三个框架技术实现的一种Web应用开发模式。在SSM框架中,Spring框架主要作为IoC容器和Bean工厂,提供依赖注入、事务管理、AOP等功能,SpringMVC框架主要负责Web层的控制器部分,处理HTTP请求和响应,而MyBatis框架则用于持久层的数据访问和管理,提供了高效且易于维护的数据库访问操作。 基于SSM框架的管理系统可以分为前台和后台两个系统。前台主要面向普通用户,提供浏览、查询、注册、登录等功能,让用户能够方便地使用系统。后台主要面向管理员或管理人员,提供对系统中各种业务数据的管理、修改、删除等功能,让管理人员能够对系统运行情况进行有效的监控和控制。 在基于SSM框架的管理系统中,需要进行技术选型、模块设计、业务实现等工作。首先,需要根据具体需求选择合适的技术方案和架构模式。其次,需要对各个模块进行梳理,按照功能划分,确定模块之间的关系和交互方式,最终实现整个系统的业务逻辑。同时,需要注意系统的可扩展性、可维护性和安全性,保证系统的数据安全,同时能够满足系统的不断发展和升级的需要。 总之,基于SSM框架的管理系统,可以通过合理运用SpringSpringMVC、MyBatis等技术,实现系统中的各种业务逻辑。开发人员需要具备扎实的Java技术和Web开发经验,同时需要熟悉相关的数据库技术和网络协议,才能够顺利地完成系统的设计和开发。 ### 回答3: SSM是目前非常流行的一种技术架构,它是SpringSpringMVC和MyBatis三个框架的结合,每个框架具有自己的优势和功能,通过整合,可以快速地搭建一个高效、可维护的管理系统。 在SSM框架下,可以将系统分为三层:表现层、业务层和持久层。表现层由SpringMVC处理用户请求和响应,业务层由Spring实现,而持久层则使用MyBatis实现数据库交互。 在搭建一个基于SSM的管理系统时,首先需要进行配置。Spring的配置包括Spring的核心配置文件、数据源的配置和事务的配置;SpringMVC的配置包括MVC配置文件、拦截器等;MyBatis的配置包括数据库连接池、Mapper文件和MyBatis的配置文件等。这些都需要进行详细的配置。 在系统开发中,可以通过Maven对项目进行管理,比如添加依赖、打包等。同时,也可以使用Spring Security对系统进行安全性的保护,实现权限控制等功能。 在具体的业务实现中,可以根据需要添加各种插件、拦截器和过滤器等,还可以使用Redis等缓存技术,提高系统的性能和效率。 总的来说,基于SSM的管理系统具有以下优点:首先,框架的整合可以提高开发效率,减少重复代码。其次,各个框架都具有良好的扩展性和可维护性,方便对系统进行升级和调整。最后,使用Maven进行项目管理,可以更好地管理依赖,提高项目效率。 当然,也需要注意SSM框架的缺点,比如框架整合带来的额外配置和调试成本,以及MyBatis可能存在的一些瓶颈等问题。综上所述,基于SSM的管理系统适合中小型项目,能够提高开发效率,降低开发难度,实现快速迭代和维护,是一种非常实用的技术方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值