springboot+mybatis 使用事务
一、一些概念
声明式的事务管理是基于AOP的,在springboot中可以通过@Transactional注解的方式获得支持,这种方式的优点是:
1)非侵入式,业务逻辑不受事务管理代码的污染。
2)方法级别的事务回滚,合理划分方法的粒度可以做到符合各种业务场景的事务管理。
本文使用目前最常用的mybatis框架来配置springboot的事务管理机制。下面进入配置方法介绍。
二、开启事务 一个注解很简单
@EnableTransactionManagement //开始事务
三、Service
在设计service层的时候,应该合理的抽象出方法包含的内容。
然后将方法用@Trasactional注解注释,默认的话在抛出Exception.class异常的时候,就会触发方法中所有数据库操作回滚,当然这指的是增、删、改。
当然,@Transational方法是可以带参数的,具体的参数解释如下:
| 属性 | 类型 | 描述 | 
|---|---|---|
| value | String | 可选的限定描述符,指定使用的事务管理器 | 
| propagation | enum: Propagation | 可选的事务传播行为设置 | 
| isolation | enum: Isolation | 可选的事务隔离级别设置 | 
| readOnly | boolean | 读写或只读事务,默认读写 | 
| timeout | int (in seconds granularity) | 事务超时时间设置 | 
| rollbackFor | Class对象数组,必须继承自Throwable | 导致事务回滚的异常类数组 | 
| rollbackForClassName | 类名数组,必须继承自Throwable | 导致事务回滚的异常类名字数组 | 
| noRollbackFor | Class对象数组,必须继承自Throwable | 不会导致事务回滚的异常类数组 | 
| noRollbackForClassName | 类名数组,必须继承自Throwable | 不会导致事务回滚的异常类名字数组 | 
代码:
@Service
public class GeoFenceService { @Autowired
private MoonlightMapper moonlightMapper; @Transactional(rollbackFor = Exception.class)//可以不加直接使用@Transactional
public int addGeoFence(GeoFence geoFence) {
String formatTime = TimeFunction.transTimeToFormatPerfect(System.currentTimeMillis());
geoFence.setCreateTime(formatTime);
geoFence.setUpdateTime(formatTime);
return moonlightMapper.insertOne(geoFence);
} @Transactional
public int batchGeoFence(List<GeoFence> geoFenceList) {
String formatTime = TimeFunction.transTimeToFormatPerfect(System.currentTimeMillis());
for (GeoFence geoFence : geoFenceList) {
geoFence.setCreateTime(formatTime);
geoFence.setUpdateTime(formatTime);
}
return moonlightMapper.insertBatch(geoFenceList);
}
}
四、测试一下
可以做一个简单的测试,主动抛出异常,测试一下是否真的能保证事务性。
在执行完插入之后,手动抛出一个空指针异常,可以发现数据真的回滚了。
@Service
public class GeoFenceService { @Autowired
private MoonlightMapper moonlightMapper; @Transactional
public int addGeoFence(GeoFence geoFence) {
String formatTime = TimeFunction.transTimeToFormatPerfect(System.currentTimeMillis());
geoFence.setCreateTime(formatTime);
geoFence.setUpdateTime(formatTime);
int count = moonlightMapper.insertOne(geoFence);
String a = null;
a.indexOf('c');
return count;
}
}
五、如果项目启动报错不要急,因为我也遇到了,下面解决一下
报错信息:
使用spring-boot做事务管理时,出现异常:The bean 'xxx' could not be injected as a 'xx.xxxx' because it is a JDK dynamic proxy that implements:
搞了半天发现是因为代理的原因;
异常信息:

解决方案:
因为加了@Transaction的类会自动开启动态代理,java的代理机制主要有JDK动态代理和CGLIB,报上面的错误是因为使用了JDK动态代理机制,我尝试开启@Transaction设置@EnableTransactionManagement(proxyTargetClass = true),问题解决;特此记录一下;
springboot+mybatis 使用事务的更多相关文章
- springboot mybatis 事务管理
		
本文主要讲述springboot提供的声明式的事务管理机制. 一.一些概念 声明式的事务管理是基于AOP的,在springboot中可以通过@Transactional注解的方式获得支持,这种方式的优 ...
 - 3分钟搞定SpringBoot+Mybatis+druid多数据源和分布式事务
		
文章来自: https://blog.csdn.net/qq_29242877/article/details/79033287 在一些复杂的应用开发中,一个应用可能会涉及到连接多个数据源,所谓多数据 ...
 - spring-boot (四) springboot+mybatis多数据源最简解决方案
		
学习文章来自:http://www.ityouknow.com/spring-boot.html 配置文件 pom包就不贴了比较简单该依赖的就依赖,主要是数据库这边的配置: mybatis.confi ...
 - springboot(整合事务和分布式事务)
		
springboot +mybatis 单数据源,事务 事务:简单理解指的是一组操作,里面包含许多个单一的逻辑,只要有一个逻辑没有执行成功 ,那么都算失败.所有的数据都回归到最初的状态(回滚) 代码实 ...
 - springboot + mybatis + 多数据源
		
此文已由作者赵计刚薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验 在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1) ...
 - springboot + mybatis +easyUI整合案例
		
概述 springboot推荐使用的是JPA,但是因为JPA比较复杂,如果业务场景复杂,例如企业应用中的统计等需求,使用JPA不如mybatis理想,原始sql调优会比较简单方便,所以我们的项目中还是 ...
 - DB数据源之SpringBoot+Mybatis踏坑过程实录系列(一)
		
DB数据源之SpringBoot+MyBatis踏坑过程(一) liuyuhang原创,未经允许进制转载 系列目录 DB数据源之SpringBoot+Mybatis踏坑过程实录(一) DB数据源之Sp ...
 - spring boot配置mybatis和事务管理
		
spring boot配置mybatis和事务管理 一.spring boot与mybatis的配置 1.首先,spring boot 配置mybatis需要的全部依赖如下: <!-- Spri ...
 - DB数据源之SpringBoot+MyBatis踏坑过程(三)手工+半自动注解配置数据源与加载Mapper.xml扫描
		
DB数据源之SpringBoot+MyBatis踏坑过程(三)手工+半自动注解配置数据源与加载Mapper.xml扫描 liuyuhang原创,未经允许禁止转载 系列目录连接 DB数据源之Spr ...
 
随机推荐
- 屏幕的遮挡层,js得到屏幕宽高、页面宽高 (window.screen.availHeight)等--
			
window.screen.availWidth 返回当前屏幕宽度(空白空间) ------当手机有输入法的时候,要注意................window.screen.availHeigh ...
 - Oracle Help 类
			
public static string ConnString = @"Data Source=xxx;USER ID=xxx;PASSWORD=xxx"; /// <sum ...
 - 解决 webpack 打包文件体积过大
			
webpack 把我们所有的文件都打包成一个 JS 文件,这样即使你是小项目,打包后的文件也会非常大.下面就来讲下如何从多个方面进行优化. 去除不必要的插件 刚开始用 webpack 的时候,开发环境 ...
 - C#程序集及程序集概念介绍
			
一.源代码-面向CLR的编译器-托管模块-(元数据&IL代码)中介绍了编译器将源文件编译成托管模块(中间语言和元数据),本文主要介绍如何将托管模块合并成程序集. 1.程序集的基本概念 2.程序 ...
 - 7、Linux权限管理-基本权限
			
1.权限概述 1.1.什么是权限? 我们可以把它理解为操作系统对用户能够执行的功能所设立的限制,主要用于约束用户能对系统所做的操作,以及内容访问的范围,或者说,权限是指某个特定的用户具有特定的系统资源 ...
 - python连接activemq
			
介绍 activeMQ是一款消息队列,关于消息队列是什么这里就不再介绍了,这里只介绍如何使用python去连接activemq进行消息的发送和接收.既然都用python去连接了,那么对于消息队列是什么 ...
 - 黑客正在使用美国NSA泄露的工具进行挖矿
			
早些年我们知道美国国家安全局囤积不少漏洞准备自己使用,结果这些漏洞以及利用工具被方程式组织获得. 随后名为影子经纪人的黑客组织获得这些漏洞和工具后又再次出售,当初的永恒之蓝漏洞就是从这里泄露的. 永恒 ...
 - facenet pyhton3.5 训练 train_softmax.py 时报错AttributeError: 'dict' object has no attribute 'iteritems'
			
报错原因:在进行facenet进行train_softmax.py训练时,在一轮训练结束进行验证时,报错AttributeError: 'dict' object has no attribute ' ...
 - 批量处理window下^M符号
			
#!/bin/ksh #set -x # #去掉文件中的^M 符号 # usage() { echo "Usage : sh ToAscll.sh [Option] [value]" ...
 - Python 实用爬虫-04-使用 BeautifulSoup 去水印下载 CSDN 博客图片
			
Python 实用爬虫-04-使用 BeautifulSoup 去水印下载 CSDN 博客图片 其实没太大用,就是方便一些,因为现在各个平台之间的图片都不能共享,比如说在 CSDN 不能用简书的图片, ...