@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秒钟