全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解在Spring Boot中使用数据库事务

我们在前面已经分别介绍了如何在spring Boot中使用JPA以及如何在Spring Boot中输出REST资源。那么关于数据库访问还有一个核心操作那就是事务的处理了,前面两篇博客小伙伴们已经见识到Spring Boot带给我们的便利了,其实不用猜,我们也知道Spring Boot在数据库事务处理问题上也给我们带来惊喜,OK,废话不多说,就来看看如何在Spring Boot中使用事务吧。

OK,那我们开始今天愉快的coding旅程吧!

创建Project并添加数据库依赖

这个没啥好说的,不懂如何创建一个Spring Boot工程的小伙伴请移步这里初识Spring Boot框架。创建的时候选择依赖时选择Web和JPA,如下图:

OK,工程创建成功之后接下来我们来添加数据库驱动,和前文一样,我这里还是以MySQL数据库为例,在pom.xml文件中添加如下依赖:

<dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.40</version>
    </dependency>

配置application.properties

配置方式还是和前文一模一样,我这里直接贴代码,含义不再赘述:

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/rest
spring.datasource.username=root
spring.datasource.password=sang

spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
spring.jackson.serialization.indent_output=true

创建实体类

实体类还是一个Person,如下:

@Entity
public class Person {
  @Id
  @GeneratedValue
  private Long id;
  private String name;
  private String address;
  private Integer age;

  public Person() {
  }

  public Long getId() {
    return id;
  }

  public void setId(Long id) {
    this.id = id;
  }

  public String getName() {
    return name;
  }

  public void setName(String name) {
    this.name = name;
  }

  public String getAddress() {
    return address;
  }

  public void setAddress(String address) {
    this.address = address;
  }

  public Integer getAge() {
    return age;
  }

  public void setAge(Integer age) {
    this.age = age;
  }

  public Person(Long id, String name, String address, Integer age) {
    this.id = id;
    this.name = name;
    this.address = address;
    this.age = age;
  }
}

创建实体类的Repository

public interface PersonRepository extends JpaRepository<Person,Long> {
}

这里因为我们的目的是测试事务,所以Repository中暂时先不写任何东西。

创建业务服务Service

创建Service接口

public interface DemoService {
  public Person savePersonWithRollBack(Person person);

  public Person savePersonWithoutRollBack(Person person);
}

创建Service实现类

@Service
public class DemoServiceImpl implements DemoService {
  @Autowired
  PersonRepository personRepository;

  @Transactional(rollbackFor = {IllegalArgumentException.class})
  @Override
  public Person savePersonWithRollBack(Person person) {
    Person p = personRepository.save(person);
    if (person.getName().equals("sang")) {
      throw new IllegalArgumentException("sang 已存在,数据将回滚");
    }
    return p;
  }

  @Transactional(noRollbackFor = {IllegalArgumentException.class})
  @Override
  public Person savePersonWithoutRollBack(Person person) {
    Person p = personRepository.save(person);
    if (person.getName().equals("sang")) {
      throw new IllegalArgumentException("sang已存在,但数据不会回滚");
    }
    return p;
  }
}

在这里我们使用到了@Transactional注解,该注解中有一个rollbackFor属性,该属性的值为数组,表示当该方法中抛出指定的异常时数据回滚,该注解还有个属性叫noRollbackFor,表示当该方法中抛出指定的异常时数据不回滚,这两个属性我们分别在两个方法中体现。

创建控制器

@RestController
public class MyController {
  @Autowired
  private DemoService demoService;

  @RequestMapping("/norollback")
  public Person noRollback(Person person) {
    return demoService.savePersonWithoutRollBack(person);
  }

  @RequestMapping("/rollback")
  public Person rollback(Person person) {
    return demoService.savePersonWithRollBack(person);
  }
}

控制器创建成功之后接下来我们就可以直接在浏览器中访问这两个地址看看效果了。

测试

首先在浏览器中输入http://localhost:8080/rollback?name=sang&age=100,我们来测试回滚的情况,访问结果如下:

看看控制台抛出的异常:

这个时候再去查看数据库,发现数据表中并没有插数据。

再在地址栏输入http://localhost:8080/norollback?name=sang&age=100,测试结果如下:

浏览器依然报错:

控制台也打印了错误,但是这个时候再去看数据库,数据已成功了。如下图:

OK,以上就是数据库事务在Spring Boot中的简单使用。

本文案例GitHub地址https://github.com/lenve/JavaEETest/tree/master/Test24-Transaction。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# springboot数据库事务  # spring boot使用事务  # 抛出  # 这两个  # 这个时候  # 再去  # 如何在  # 如下图  # 实体类  # 器中  # 在这里  # 有个  # 中有  # 不懂  # 给我们  # 还有一个  # 不回  # 为例  # 上也  # 就来  # 报错  # 多说 


相关文章: 建站之星收费标准详解:套餐费用及年费价格表一览  如何快速搭建FTP站点实现文件共享?  宝塔面板创建网站无法访问?如何快速排查修复?  西安专业网站制作公司有哪些,陕西省建行官方网站?  建站之星伪静态规则如何设置?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  建站主机类型有哪些?如何正确选型  如何在建站宝盒中设置产品搜索功能?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  寿县云建站:智能SEO优化与多行业模板快速上线指南  公司网站设计制作厂家,怎么创建自己的一个网站?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  移民网站制作流程,怎么看加拿大移民官网?  如何在IIS管理器中快速创建并配置网站?  网站制作难吗安全吗,做一个网站需要多久时间?  香港服务器选型指南:免备案配置与高效建站方案解析  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  外汇网站制作流程,如何在工商银行网站上做外汇买卖?  小型网站建站如何选择虚拟主机?  Swift中swift中的switch 语句  潮流网站制作头像软件下载,适合母子的网名有哪些?  香港服务器部署网站为何提示未备案?  宝塔建站助手安装配置与建站模板使用全流程解析  如何在香港免费服务器上快速搭建网站?  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  如何选购建站域名与空间?自助平台全解析  建站之星代理商如何保障技术支持与售后服务?  如何通过WDCP绑定主域名及创建子域名站点?  建站之星下载版如何获取与安装?  PHP 500报错的快速解决方法  为什么Go需要go mod文件_Go go mod文件作用说明  如何通过建站之星自助学习解决操作问题?  seo网站制作优化,网站SEO优化步骤有哪些?  昆明网站制作哪家好,昆明公租房申请网上登录入口?  建站之星安装提示数据库无法连接如何解决?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  如何选择高效便捷的WAP商城建站系统?  西安大型网站制作公司,西安招聘网站最好的是哪个?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?  高防服务器租用首荐平台,企业级优惠套餐快速部署  如何在香港服务器上快速搭建免备案网站?  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  ,巨量百应是干嘛的?  建站之星后台管理如何实现高效配置?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  七夕网站制作视频,七夕大促活动怎么报名?  建站之星如何修改网站生成路径?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  建站主机系统SEO优化与智能配置核心关键词操作指南 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。