1.Spring中的applicationContext.xml配置错误导致的异常 异常信息: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.ssm.service.BTestService.getPhoneKey at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:2…
背景 近期在公司做的一个项目,用的是SpringMVC框架,数据库用的是MySql,刚開始并没有增加事务,后因业务须要必须事务处理. 问题的产生和解决 使用事务,直接问百度,我选择的是注解的方式. 在配置文件里配置事务管理器和驱动: <tx:annotation-driven transaction-manager="transactionManager"/> <bean id="transactionManager" class="or…
如题,在数据库批量操作方法上使用@Transactional注解,其中一条数据抛出异常了,却死活不回滚. 批量操作方法是公有的,spring也是默认支持事务的,排除代码层面问题,那么就看看数据库是否支持事务吧: mysql> show engines; +--------------------+---------+----------------------------------------------------------------+--------------+------+----…
Synchronized用于线程间的数据共享,而ThreadLocal则用于线程间的数据隔离. 在我完成一个项目的时候,遇到了一个Spring事务不回滚的问题,通过aspectJ和@Transactional注解都无法完成对于事务的回滚,经过查看博客和文档 默认回滚RuntimeException Service内部方法调用 Spring父子容器覆盖 代码已经上传到 https://github.com/morethink/transactional 异常 下面是@Transactional的注…
最近试了试spring的回滚功能,根据网上的教程配置怎么都不好使,遂寻找答案, 网上的答案都是这么讲的: 1. 检查你方法是不是public的. 2. 你的异常类型是不是unchecked异常.如果我想check异常也想回滚怎么办,注解上面写明异常类型即可. @Transactional(rollbackFor=Exception.class) 类似的还有norollbackFor,自定义不回滚的异常. 3. 数据库引擎要支持事务,如果是mysql,注意表要使用支持事务的引擎,比如innodb,…
转载自:http://blog.csdn.net/lovejavaydj/article/details/7635848 试验方法: 写一个单元测试,调用一个service层方法(发生对数据库进行写操作的方法--insert.update.delete)即可. 试验过程: 定义一个service方法如下: public SMSTiming createSMSTiming(SMSTiming smsTiming){ SMSTiming s= this.getSmsTimingDAO().creat…
if(userSave){ try { userDao.save(user); userCapabilityQuotaDao.save(capabilityQuota); } catch (Exception e) { logger.info("能力开通接口,开户异常,异常信息:"+e); } } 类似上面这样的方法不会回滚 (一个方法出错,另一个方法不会回滚) 下面的方法回滚(一个方法出错,另一个方法会回滚): if(userSave){ try { userDao.save(use…
Spring的AOP事务管理默认是针对unchecked exception回滚. 也就是默认对RuntimeException()异常极其子类进行事务回滚. Exception作为基类,下面还分checked exception和unchecked exception.如果客户端可以通过其他的方法恢复异常,那么这种异 常就是checked exception:如果客户端对出现的这种异常无能为力,那么这种异常就是Unchecked exception:简单来说,继承于 RuntimeExcept…
研究了好长时间,都不知道原因,也不能解决. 控制台又没有报异常,但是就是一直回滚.注释掉spring声明式配置的代码,就能正确的更新数据. 从网上看了,别人的文章 http://blog.csdn.net/molingduzun123/article/details/49383235 按照文章中的,加上@Rollback(false),在@Test下面. 设置不要自动回滚,然后正常了.…
mysql的引擎常用的有两个,一个MyISAM,另一个是InnoDB,mysql默认的为MyISAM,而InnoDB才是支持事务的.所以一般需要修改下,如何修改就不说了. 事务需要依赖数据库,好久没使用声明式事务,今天试了下.关键配置如下. <tx:advice id="transactionAdvice" transaction-manager="transactionManager"> <tx:attributes> <tx:met…