Java 框架实战 springAOP 实现数据库事务操作

今天就是平安夜了

伙伴们都要平平安安的哈

那么开始今天的分享

先来了解一下事务的概念:

事务是一系列作为一个逻辑单元来执行的操作的集合。它是数据库维护数据一致性的单位,它讲数据库从一个一致状态,转变为新的另外一个一致状态。

简单来说就是:对一组数据进行处理,要么所有操作都成功,要么全部都失败,这样就保证了数据始终一直的状态,维护了数据的完整和可靠性。

我们来做个小例子,模拟一下转账的流程。

先来写一下数据库

数据库内容:

来写一下 DAO 层的接口,两个操作数据库的方法,一个是增加钱数,一个是减少钱数

实现这两个方法。

在 service 层定义一个转账的方法

转账操作的业务逻辑

配置文件

测试一下

看一下数据库的结果:转账成功了

这是程序正常运行,没有bug的情况,万一程序在转账的过程中出错了呢?

程序出现了 bug 。再测试一下

看一下数据库的结果

我们总共是3000,现在张三和李四加起来是2900,转丢了100。现在你明白我们为什么要使用事务了吧!

事务的属性

原子性(atomicity):一个事务是一个不可分割的工作单位,事务中包括的所有操作要么都做,要么都不做。

一致性(consistency):事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。

隔离性(isolation):一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。

持久性(durability):持续性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

这四个属性通常称为 ACID 特性。

利用 spring 基于 xml 配置实现事务。

事务原本是数据库中的概念,是在 dao 层,一般情况下,我们会把事务管理提升到的业务层 (service)。这是为了更好的是用事务来管理我们的业务逻辑,spring 并不直接管理事务,而是提供了多种事务管理器 jdbc (自定义封装jdbc,jdbctemplate,mybatis ) 使用:DataSourceTransactionManager

我们来配置一下:

引入jar,引入aop约束

aopalliance-1.0.jar

spring-aop-4.2.1.RELEASE.jar

spring-tx.jar

xml配置事务

现在让我们来测试一下

转账失败了,查看一下数据库

没有使用事务时,转账过程中出现 bug,就会导致我们扣钱成功了,但是钱转入失败了,钱的总数就少了。

使用了事务之后,转账过程中程序出现 bug ,我们的扣除的钱可以回到原来的账户,不会造成损失。

各位我解释的还清楚吗?

平安夜快乐

拜拜!

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20171224A0LJZA00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券