SpringBoot事务的使用(一)

失踪人口回归了!!!!好久没有更新博客了

SpringBoot事务的使用(一)

背景:最开始了解事务是在做一个类似于抢购的模块,当时的场景无法通过乐观锁去解决,因此直接通过事务锁住整个模块。最近一段写代码用的事务比较多,之前没怎么认真看过对应的章节内容,用起来的时候还是稀里糊涂的,所以好好了解一下。
PS:简单的基础类代码在这里就不展示了
事务的基本概念在这里就不介绍了,这篇博客的主要内容是测试事务在本类方法中调用其他非事务方法的时候是否可以完成事务的回滚。

展示基本代码

基本的测试代码如下

@Override@Transactional(rollbackFor = Exception.class)public int insertNews(News news) throws Exception {long mark = System.currentTimeMillis();System.out.println("time:" + mark +":" + JSON.toJSONString(news));newsDao.insertNews(news);System.out.println("time:" + mark +":" + JSON.toJSONString(news));insertLabel(news);return News.SUCCESS;}private void insertLabel(News news) {if(!CollectionUtils.isEmpty(news.getSuggestTitle())) {newsDao.insertNewsLabel(news.getId(), news.getSuggestTitle());} else {throw new RuntimeException("输入参数错误");}}// input: 6552290168697520659_!_110_!_news_military_!_美军终于怕了:彩虹无人机已实战干掉300多目标_!_无人机

数据这块是之前做一些文本测试的时候从github上找的一些新闻标题数据_!_表示分割,在这里拿来作处理,第一个是新闻ID,第二个是新闻的种类编码,第三个是新闻种类,第四个是新闻标题,第五个是新新闻标签
代码的功能:首先将新闻数据写入news数据表,如果有新闻标签,则将标签写入newsLabel数据表

测试场景一:正常执行

在这里插入图片描述

图1
现可以从图1中看到creating transactional 和 releasing transactional ,表明事务的创建和释放,mybatis的操作在事务内完成
测试场景二:被调用方法抛出Exceltion的错误异常
目的: 测试数据是否被插入以及事务的情况

代码如下

@Override@Transactional(rollbackFor = Exception.class)public int insertNews(News news) throws Exception {long mark = System.currentTimeMillis();System.out.println("time:" + mark +":" + JSON.toJSONString(news));newsDao.insertNews(news);System.out.println("time:" + mark +":" + JSON.toJSONString(news));insertLabel(news);return News.SUCCESS;}private void insertLabel(News news) throws Exception {if(!CollectionUtils.isEmpty(news.getSuggestTitle())) {newsDao.insertNewsLabel(news.getId(), news.getSuggestTitle());} else {throw new Exception("输入参数错误");}}
测试输入数据:6552290168697520654_!110!news_military!美军终于怕了:彩虹无人机已实战干掉300多目标!_彩虹5,导弹,攻击机,最大起飞重量,无人机

该数据是可以保证程序正常执行。
打印出来的日志有这么一条:

在这里插入图片描述

当断点走过 newsDao.insertNews(news); 查询数据表,数据表显示为空,测试数据并未插入数据表中,放开断点走完全部代码,事务提交(默认的事务隔离级别,好像是未提交读),数据写入数据表中,
这段事务的日志是在两个写入表操作都执行完成才进行事务提交的。在这里让子方法(insertLabel)抛出一场,测试事务的状态

在这里插入图片描述在这里可以看到,抛出异常后事务并未提交sql的信息,直接回滚,数据表中自然也就没有数据了,当然,在这个事务并为提交,因此也并未存在任何数据表操作

先发布一版,后续过几天再写


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部