@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, 15210712345
2017-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已经开启,所以此时挂起事务2
2017-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 完成---数据库中的值为 {} 开始 sleep
2017-12-23 18:15:52 [http-nio-9082-exec-5] INFO c.c.service.impl.UserServiceImpl2 - sleep结束
## 事务三执行完毕