事务具有以下 4 个特性,即原子性、一致性、隔离性和持久性,这 4 个属性称为 ACID 特性。
一致性(Consistency):事务必须保证数据库从一个一致性状态变到另一个一致性状态,一致性和原子性是密切相关的。
原子性(Atomicity):一个事务是一个不可分割的工作单位,事务中包括的动作要么都做要么都不做,这里的原子性并不能保证事务一气呵成执行完,期间不被其它事务插足,它只能保证事务中途出了问题可以回滚回原始状态,所以就引出了隔离级别的概念。
隔离性(Isolation):一个事务的执行不能被其它事务干扰,即一个事务内部的操作及使用的数据对并发的其它事务是隔离的,并发执行的各个事务之间不能互相打扰。
持久性(Durability):持久性也称为永久性,指一个事务一旦提交,它对数据库中数据的改变就是永久性的,后面的其它操作和故障都不应该对其有任何影响。

声明:下面的样例项目我用的是b站的一个教程里提供的,但是代码都是自己敲的。
项目背景:
在我们商城购物时,用户购买物品后,物品的库存会减少,订单的信息会增加一条。这两个sql语句是紧密联系的,我们希望它要么都发生,要么都别发生,所以就需要使用事务。

首先先创建一个表,然后添加几条数据。

java 局部事务在什么场景使用 java事务应用场景_java 局部事务在什么场景使用


java 局部事务在什么场景使用 java事务应用场景_java 局部事务在什么场景使用_02


然后新建一个spring项目,已经上传到github了:https://github.com/yqs-281876918/springTransaction

ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
BuyGoodService buyGoodService=(BuyGoodService) context.getBean("buyGoodService");
buyGoodService.buy(1001,1);
buyGoodService.buy(1002,999);

测试后发现购买1份1001不会出错,库存减少了,订单信息也正常出来了。
当买999份1002时由于抛了库存不足异常,会导致事务回滚,所以库存和订单都不会更新。