springboot有关事务的实现

一、事务
1.事务的概念

事务是指一组操作,这些操作要么全部成功,要么全部失败。如果在一组操作中有一个操作失败了,那么整个事务都应该回滚,即撤销已经执行的操作,从而保证数据的一致性和完整性。

2.事务的四个特性(ACID 特性)
  • Atomicity(原子性):事务的所有操作要么全部成功,要么全部失败。
  • Consistency(一致性):事务执行前后,数据的完整性和一致性保持不变。
  • Isolation(隔离性):事务的执行不受其他事务的干扰,即并发执行的事务之间应该相互隔离。
  • Durability(持久性):事务提交后,它的结果应该永久保存在数据库中。
3.Spring Boot 中的事务

在 Spring Boot 中,我们可以使用事务管理器来管理事务。事务管理器可以确保一系列操作要么全部成功,要么全部失败,从而保证数据的一致性和完整性。

Spring Boot 中的事务管理器是通过 AOP(面向切面编程)实现的,它可以拦截带有 @Transactional 注解的方法,并在方法执行前后自动开启和提交事务。如果方法执行过程中发生异常,事务管理器会自动回滚事务,从而保证数据的一致性和完整性。

二、IDEA具体实现(在springBoot进行事务管理)

1.开启事务

@EnableTransactionManagement

2.设置事务

@Transactional(isolation = Isolation.DEFAULT)

@Transactional(propagation = Propagation.REQUIRED)

1.在启动类中添加开始事务注解@EnableTransactionManagement
复制代码
@SpringBootApplication
@EnableTransactionManagement
public class SpringbootCenter01TxApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringbootCenter01TxApplication.class, args);
    }

}
2.在需要开启事物的方法上面添加设置事务注解@Transactional
复制代码
@Service
public class CustomerServiceImp  implements ICustomerService{

    @Autowired
    CustomerMapper dao;

    @Transactional
    @Override
    public void add() {
        dao.insert(new Customer("西安","五星级","ypp"));
        int a=10/0;
        dao.insert(new Customer("宝鸡","五星级","kyz"));
    }
}
3.Controller层代码
复制代码
@RestController
//@Controller
public class CustomerController {
    @Autowired
    ICustomerService service;
    
    //@ResponseBody
    @RequestMapping("/add")
    public String add() {
        service.add();
        return "成功";
    }
}
相关推荐
DBA小马哥8 分钟前
时序数据库是什么?能源行业国产化替换的入门必看
数据库·时序数据库
后端AI实验室12 分钟前
我把一个生产Bug的排查过程,交给AI处理——20分钟后我关掉了它
java·ai
凉年技术2 小时前
Java 实现企业微信扫码登录
java·企业微信
爱可生开源社区2 小时前
某马来西亚游戏公司如何从 SQL Server 迁移至 OceanBase?
数据库
狂奔小菜鸡3 小时前
Day41 | Java中的锁分类
java·后端·java ee
hooknum3 小时前
学习记录:基于JWT简单实现登录认证功能-demo
java
程序员Terry4 小时前
同事被深拷贝坑了3小时,我教他原型模式的正确打开方式
java·设计模式
NE_STOP4 小时前
MyBatis-缓存与注解式开发
java
码路飞4 小时前
不装 OpenClaw,我用 30 行 Python 搞了个 QQ AI 机器人
java
小瓦码J码4 小时前
PostgreSQL表名超长踩坑记
数据库·postgresql