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结束## 事务三执行完毕
阅读全文
0 0
- Spring事务传播机制-REQUIRES_NEW
- spring事务传播机制-REQUIRED嵌套REQUIRES_NEW
- Spring事务传播机制
- Spring事务传播机制
- Spring事务传播机制
- spring事务传播机制
- Spring事务传播机制
- Spring事务传播机制
- Spring 事务传播机制
- spring事务传播机制
- Spring事务传播机制
- spring 事务传播机制
- Spring事务传播机制
- Spring事务传播机制
- Spring事务传播机制
- Spring事务传播机制
- spring事务传播机制
- Spring事务传播机制
- quartz之Hello
- redis设置密码和redis主从复制
- java中Volatile变量
- 使用babel深入理解es7的decorator
- 南邮CTF逆向题第二道ReadAsm2解题思路
- Spring事务传播机制-REQUIRES_NEW
- caffe中如何设置某层不参与反向传播
- Socket 长连接与短连接,心跳
- Spring框架 login.jsp跳转index.jsp
- 十三.ARM裸机学习之NandFlash详解
- 如何在linux中安装jdk
- 团队开发、代码维护利器——github
- 分布式缓存Redis之内存优化
- 计算机网络——应用层