1、问题描述
springboot项目中配置事务,以前通过标签用过,上个内部项目,因为是在别人代码中使用了,发现好像没起作用(然后因为有框架保证,就没计较了),新启动项目又用到,验证了下,springboot项目下配置两个标签就可以了。
2、解决方案
2.1 说明
(1)其实就两个标签,一个用到启动类中(@EnableTransactionManagement),另一个就是那里需要就配置到哪里(@Transactional);
(2)方案,就随便找了个以前的测试项目,一个方法中包含:保存一条数据到数据库中和一个1除以0代码,然后看下加不加事务标签有什么区别;
2.2 代码说明
(1)controller类
@ResponseBody
@GetMapping("/tstest")
public String tstest() {
this.userService.tstest();
return "SUCCESS";
}
(2)service类
public void tstest() {
//保存
UserEntity userEntity = new UserEntity();
userEntity.setType(0);
userEntity.setOpenid("1111");
insert(userEntity);
//报错,回滚
int i = 1/0;
System.out.println(i);
}
2.3 验证1,没有事务
不加事务标签,代码如上。
(1)先清空数据库;
(2)执行tstest请求;
data:image/s3,"s3://crabby-images/ef0fe/ef0fe325e062534a690fc56f2e82e7b04d57e005" alt=""
发现insert代码行执行完,数据就存到数据库中了。
data:image/s3,"s3://crabby-images/383b4/383b4b313e1aefd067f286bdf802a5eede8bcbcf" alt=""
接着执行完成(1/0),虽然报错代码报错,但是数据库中数据还是存在的,数据没有回滚,没有保持一致性。
data:image/s3,"s3://crabby-images/9fcbb/9fcbb36635d769a2a6759e4f9067ce711754865a" alt=""
2.4 验证2,有事务
(1)增加两个标签,一个是启动类方法上,一个是tstest方法上。 data:image/s3,"s3://crabby-images/e4d9c/e4d9cdf8e834cd4803645542bcb8048a1e0abb68" alt=""
data:image/s3,"s3://crabby-images/53e75/53e753fc92c420ef230fa2332e0f7a0a4856c408" alt=""
(2)首先清除数据,执行到insert处 data:image/s3,"s3://crabby-images/2970e/2970e76992db23d8ff9c6d007c323bbe8dd1c513" alt=""
发现虽然insert代码行执行完成了,但是这时候数据库中并没有数据,然后执行完,代码报错,数据回滚,数据库中并没有存入数据,说明事务起到到该有的作用,数据回滚了。
data:image/s3,"s3://crabby-images/d9b15/d9b15e651afa4a90002bef3e67ea30bc8cec86bd" alt=""
更多信息请关注公众号:「软件老王」,关注不迷路,软件老王和他的IT朋友们,分享一些他们的技术见解和生活故事。 data:image/s3,"s3://crabby-images/779e4/779e46b5a54ca0b6bb6f0760b992d08775a48b1f" alt=""
|