springboot开启事务很简单,只需要一个注解@Transactional 就可以了。因为在springboot中已经默认对jpa、jdbc、mybatis开启了事事务,引入它们依赖的时候,事物就默认开启。当然,如果你需要用其他的orm,比如beatlsql,就需要自己配置相关的事物管理器。

准备阶段
以上一篇文章的代码为例子,即springboot整合mybatis,上一篇文章是基于注解来实现mybatis的数据访问层,这篇文章基于xml的来实现,并开启声明式事务。
环境依赖
在pom文件中引入mybatis启动依赖:
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.0</version>
</dependency>
引入MySQL 依赖
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.29</version>
</dependency>
初始化数据库脚本
-- create table `account`
# DROP TABLE `account` IF EXISTS
CREATE TABLE `account` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL,
`money` double DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
INSERT INTO `account` VALUES ('1', 'aaa', '1000');
INSERT INTO `account` VALUES ('2', 'bbb', '1000');
INSERT INTO `account` VALUES ('3', 'ccc', '1000');
配置数据源
spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.jdbc.Driver mybatis.mapper-locations=classpath*:mybatis/*Mapper.xml mybatis.type-aliases-package=com.forezp.entity
通过配置mybatis.mapper-locations来指明mapper的xml文件存放位置,我是放在resources/mybatis文件下的。mybatis.type-aliases-package来指明和数据库映射的实体的所在包。
经过以上步骤,springboot就可以通过mybatis访问数据库来。
创建实体类
public class Account {
private int id ;
private String name ;
private double money;
getter..
setter..
}
数据访问dao 层
接口:
public interface AccountMapper2 {
int update( @Param("money") double money, @Param("id") int id);
}
mapper:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.forezp.dao.AccountMapper2">
<update id="update">
UPDATE account set money=#{money} WHERE id=#{id}
</update>
</mapper>
service层
@Service
public class AccountService2 {
@Autowired
AccountMapper2 accountMapper2;
@Transactional
public void transfer() throws RuntimeException{
accountMapper2.update(90,1);//用户1减10块 用户2加10块
int i=1/0;
accountMapper2.update(110,2);
}
}
@Transactional,声明事务,并设计一个转账方法,用户1减10块,用户2加10块。在用户1减10 ,之后,抛出异常,即用户2加10块钱不能执行,当加注解@Transactional之后,两个人的钱都没有增减。当不加@Transactional,用户1减了10,用户2没有增加,即没有操作用户2 的数据。可见@Transactional注解开启了事物。
结语
springboot 开启事物很简单,只需要加一行注解就可以了,前提你用的是jdbctemplate, jpa, mybatis,这种常见的orm。
源码下载:https://github.com/forezp/SpringBootLearning
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# springboot声明式事务
# spring
# boot
# 开启事务
# spring声明式事务
# Spring实战之使用注解实现声明式事务操作示例
# Spring深入刨析声明式事务注解的源码
# spring 注解如何开启声明式事务
# 就可以
# 很简单
# 只需要
# 来实现
# 的是
# 我是
# 如果你
# 放在
# 其他的
# 的钱
# 上一
# 管理器
# 这篇文章
# 你用
# 不加
# 抛出
# 一篇文章
# 需要用
# 大家多多
# 源码下载
相关文章:
如何高效搭建专业期货交易平台网站?
威客平台建站流程解析:高效搭建教程与设计优化方案
建站之星如何实现网站加密操作?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
大连网站设计制作招聘信息,大连投诉网站有哪些?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
高防服务器:AI智能防御DDoS攻击与数据安全保障
javascript中的try catch异常捕获机制用法分析
建站168自助建站系统:快速模板定制与SEO优化指南
临沂网站制作公司有哪些,临沂第四中学官网?
如何在香港服务器上快速搭建免备案网站?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
导航网站建站方案与优化指南:一站式高效搭建技巧解析
常州企业建站如何选择最佳模板?
如何基于PHP生成高效IDC网络公司建站源码?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
小型网站建站如何选择虚拟主机?
南京网站制作费用,南京远驱官方网站?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
如何在服务器上三步完成建站并提升流量?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
活动邀请函制作网站有哪些,活动邀请函文案?
如何在香港免费服务器上快速搭建网站?
如何正确下载安装西数主机建站助手?
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何在企业微信快速生成手机电脑官网?
linux top下的 minerd 木马清除方法
香港服务器部署网站为何提示未备案?
枣阳网站制作,阳新火车站打的到仙岛湖多少钱?
高防服务器租用指南:配置选择与快速部署攻略
网站专业制作公司有哪些,做一个公司网站要多少钱?
香港网站服务器数量如何影响SEO优化效果?
如何通过多用户协作模板快速搭建高效企业网站?
,在苏州找工作,上哪个网站比较好?
外贸公司网站制作哪家好,maersk船公司官网?
模具网站制作流程,如何找模具客户?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
零基础网站服务器架设实战:轻量应用与域名解析配置指南
如何用PHP工具快速搭建高效网站?
如何通过服务器快速搭建网站?完整步骤解析
ppt制作免费网站有哪些,ppt模板免费下载网站?
魔方云NAT建站如何实现端口转发?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
如何挑选最适合建站的高性能VPS主机?
如何挑选优质建站一级代理提升网站排名?
图册素材网站设计制作软件,图册的导出方式有几种?
*请认真填写需求信息,我们会在24小时内与您取得联系。