Spring事务传播机制-REQUIRES_NEW

来源:互联网 发布:淘宝账号登陆不了 编辑:程序博客网 时间:2024/06/07 00:22

@Transactional
如果加在class上,则默认没个方法都会有起作用、也就是说每个方法都会开启一个事务,包括查询
所以尽量不要加在class上

先看第一个propagation REQUIRES_NEW的用法

/**     * REQUIRES_NEW 如果该方法update已经开启了老事务,则新事务会被挂起,直到老事务执行完成以后才执行新的事务<br/>     * 注意: 并不是新事务等着老事务把update方法的所有code都执行完才开始执行新事物的update方法<br/>     * 因为只有执行到userMapper.update(userParam)才开启事务, 此时才会挂起老的事务     */    @Transactional(propagation = Propagation.REQUIRES_NEW)    @Override    public Integer update(UserRecord userParam) {        logger.info("开始执行 update {}, {}", userParam.getId(), userParam.getPhone());        int result = userMapper.update(userParam);        try {            logger.info("update 完成---数据库中的值为 {} 开始 sleep");            Thread.sleep(1000 * 10);            logger.info("sleep结束");        } catch (InterruptedException e) {            e.printStackTrace();        }        return result;    }

测试 执行三个http请求, 每个请求间隔大概2秒钟
http://localhost:9082/coffee.controller/update?phone=15210712345
http://localhost:9082/coffee.controller/update?phone=15210712346
http://localhost:9082/coffee.controller/update?phone=15210712347

2017-12-23 18:15:22 [http-nio-9082-exec-4] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 update 28, 152107123452017-12-23 18:15:22 [http-nio-9082-exec-4] INFO  c.c.service.impl.UserServiceImpl2 - update 完成---数据库中的值为 {} 开始 sleep ## 执行到这的时候  事务1已经开启了2017-12-23 18:15:24 [http-nio-9082-exec-6] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 update 28, 15210712346## 第二个请求已经到达,注意一下,此时还未开启事务2, 所以update方法的第一行代码 是执行的## 因为事务1已经开启,所以此时挂起事务22017-12-23 18:15:26 [http-nio-9082-exec-5] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 update 28, 15210712347## 请求3到达,原理同上2017-12-23 18:15:32 [http-nio-9082-exec-4] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束## 此时,事务1已经执行完毕, 这时候轮到事务2了2017-12-23 18:15:32 [http-nio-9082-exec-6] INFO  c.c.service.impl.UserServiceImpl2 - update 完成---数据库中的值为 {} 开始 sleep## 事务2执行中2017-12-23 18:15:42 [http-nio-9082-exec-6] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束## 事务2执行完毕,接着轮到事务3开始了2017-12-23 18:15:42 [http-nio-9082-exec-5] INFO  c.c.service.impl.UserServiceImpl2 - update 完成---数据库中的值为 {} 开始 sleep2017-12-23 18:15:52 [http-nio-9082-exec-5] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束## 事务三执行完毕
原创粉丝点击