@Transactional注解使用及同时使用try catch导致注解失效问题

一  Transactional注解使用

        @Tranasctional注解是Spring 框架提供的声明式注解事务解决方案,我们在开发中使用事务保证方法对数据库操作的原子性,要么全部成功,要么全部失败。

        @Tranasctional注解基本使用

        这段代码是一个简单的使用@Tranasctional注解,需要删除临时表中所有数据,对数据库进行了操作所以使用了该注解。同样的对于新增、修改操作也需要使用该注解,在查询操作则是加上加上参数@Transactional(readOnly = true)

         在后端API编写过程中,大家可能在service层的涉及到数据库操作的方法中使用该注解,对于和我一样的新手大家可能更多的是被项目经理要求说在涉及到数据库操作的方法上必须使用@Transactional注解,也只是模模糊糊知道使用该注解作用是发生错误时让数据库回滚,但最近我在使用该注解过程中就遇到了一些坑,在这里简单记录下。

二  @Transactional与try catch同时使用

        try catch大家想必也不陌生,用来处理异常,但大家在使用@Tranasctional注解的方法内又使用了try catch 来处理异常,大家有没有考虑过这样做对吗?大家可能是最初像我一样只求简单把功能实现,对单表操作好像没什么问题,也并没有去深究我应不应该这样写,所以这次我就遇到了坑!

        这次任务是涉及到新增用户时在方法内对三张表进行存储操作,要求当任意一张表发生错误时三张表全部进行回滚,业务代码大致如下:

        当发生错误时我在catch里面打印出了错误,但是在测试过程中发现了:当我第一、二张表存入成功,但第三张表存入失败后,按照设想应该三张表全部回滚,但事实只对第三张表进行了回滚,一二两个表还是存入了数据库。

        查阅了原因是存在@Tranasctional注解失效的问题。

三 @Tranasctional注解失效

        如若在添加数据的过程中,中间有一个数据添加失败,那么catch的作用就是捕获该异常, 只让这一条数据不添加到数据库中。 后面的数据或者是这条数据之前的数据,依然可以添加到数据库中。目的是不让业务中断 因为catch你已经捕获异常了,所以业务不会中断。但Transactional注解的作用是添加数据的过程中,中间有一个数据添加失败,那么之前添加到数据库中的数据全部回滚。后面的数据也不会添加到数据库中保证数据安全。

        当在方法中异常被catch捕获到,catch对其进行了处理,在catch中即没有继续抛出异常也没有手动回滚数据库,便会出现:异常被catch捕获到做了处理,异常的生命周期已经结束,而并没有将异常抛出所以,所以没有被@Transactional注解捕获到,导致该注解失效,数据库没有全部回滚该事务。

四 解决方法

        解决方法在上面也提到了,很简单,在catch中继续抛出异常或者手动回滚事务。两种方法我均展示在下面代码中。手动回滚和抛出异常选择一种其实就可以实现了。

        以上内容仅是我对项目中遇到的问题做一些记录,水平有限,若有不对欢迎指正!

要安装Docker并安装插件,可以按照以下步骤进行操作: 1. 首先,安装Docker。可以按照官方文档提供的步骤进行安装,或者使用适合您操作系统的包管理器进行安装。 2. 安装Docker Compose插件。可以使用以下方法安装: 2.1 下载指定版本的docker-compose文件: curl -L https://github.com/docker/compose/releases/download/1.21.2/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose 2.2 赋予docker-compose文件执行权限: chmod +x /usr/local/bin/docker-compose 2.3 验证安装是否成功: docker-compose --version 3. 在安装插件之前,可以测试端口是否已被占用,以避免编排过程中出错。可以使用以下命令安装netstat并查看端口号是否被占用: yum -y install net-tools netstat -npl | grep 3306 现在,您已经安装了Docker并安装了Docker Compose插件,可以继续进行其他操作,例如上传docker-compose.yml文件到服务器,并在服务器上安装MySQL容器。可以参考Docker的官方文档或其他资源来了解如何使用Docker和Docker Compose进行容器的安装和配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Docker安装docker-compose插件](https://blog.youkuaiyun.com/qq_50661854/article/details/124453329)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Docker安装MySQL docker安装mysql 完整详细教程](https://blog.youkuaiyun.com/qq_40739917/article/details/130891879)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值