关于Spring的@Transaction导致数据库回滚全部生效问题(又删库跑路)

关于Spring的事务管理,如果使用默认配置会导致数据库中的数据出现异常时,整个事务会被回滚,包括正常执行的数据也会被回滚,这种情况下可能会造成严重的数据丢失。以下是我总结出的关于这个问题的完整攻略:

问题分析

在 Spring 中,默认情况下,使用 @Transactional 注解添加的事务会使用最悲观的隔离级别(TransactionDefinition.ISOLATION_DEFAULT),设置了自动回滚(propagation = Propagation.REQUIRED, rollbackFor = Exception.class)。

解决方案

方案一:只回滚异常的操作

不是所有的操作都需要回滚,有些操作可以继续进行。我们可以通过标记异常来决定是否回滚事务。我们可以通过设置 @Transactional 注解的 rollbackFor 属性,来指示需要回滚的异常:

@Service
public class MyService {
    @Transactional(rollbackFor = MyException.class)
    public void func() throws MyException {
        // some code
    }
}

在这个例子中,如果抛出了 MyException 异常,就会回滚当前事务。

方案二:多事务管理器来管理数据源

使用多个事务管理器来分别管理不同的数据源,这样就能保证每个数据源独立进行事务管理。以下是一个使用多个事务管理器的示例:

@Configuration
public class DataSourceConfiguration {
    @Bean
    @Primary
    @ConfigurationProperties("spring.datasource.primary")
    public DataSource primaryDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Bean
    @ConfigurationProperties("spring.datasource.secondary")
    public DataSource secondaryDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Bean
    public PlatformTransactionManager primaryTransactionManager() {
        return new DataSourceTransactionManager(primaryDataSource());
    }

    @Bean
    public PlatformTransactionManager secondaryTransactionManager() {
        return new DataSourceTransactionManager(secondaryDataSource());
    }
}

在这个例子中,我们使用了两个数据源,每个数据源都有自己的事务管理器。这样做可以保证每个数据源在事务管理时是独立的。

总结

以上是关于 Spring 的 @Transactional 导致数据库回滚全部生效问题的完整攻略。我们可以通过设置 rollbackFor 属性或者使用多个事务管理器来解决这个问题。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:关于Spring的@Transaction导致数据库回滚全部生效问题(又删库跑路) - Python技术站

(0)
上一篇 2023年5月21日
下一篇 2023年5月21日

相关文章

  • extundelete实现Linux下文件 文件夹数据恢复教程

    下面是“extundelete实现Linux下文件 文件夹数据恢复教程”的完整攻略。 一、准备工作 在使用extundelete前,需要做一些准备工作。 1.备份 在恢复文件或文件夹之前,务必备份磁盘上的数据,以免造成更大的损失。 2.停止写入 在文件或文件夹丢失后,为了避免数据被覆盖,需要尽快停止对磁盘的写入操作。 3.安装extundelete 在Ubu…

    database 2023年5月22日
    00
  • Java用 Rhino/Nashorn 代替第三方 JSON 转换库

    使用 Rhino/Nashorn 代替第三方 JSON 转换库的攻略如下: 背景 在 Java 开发中,我们经常需要将 Java 对象转成 JSON 格式,或者将 JSON 格式转成 Java 对象。通常情况下,我们会依赖第三方 JSON 转换库,如 fastjson、Jackson、Gson 等。但是,Rhino 和 Nashorn 都提供了 JSON 的…

    database 2023年5月21日
    00
  • 常用的MongoDB查询语句的示例代码

    在这里我为您提供MongoDB查询语句的攻略,具体内容如下: 一、MongoDB查询语句 MongoDB是一款NoSQL数据库,在进行查询数据时,使用的语句和关系型数据库并不相同。下面我们将介绍MongoDB的基本查询语句。 1. db.collection.find() db.collection.find()是MongoDB中最常用的查询语句,用于查询集…

    database 2023年5月21日
    00
  • Windows下安装Bun像Node或Deno的现代JS运行时

    下面,我将为您讲解”Windows下安装Bun像Node或Deno的现代JS运行时”的完整攻略。本攻略分为三个部分:安装Chocolatey、安装Bun、验证安装。 1. 安装Chocolatey Chocolatey是Windows平台上的包管理器,可以简化应用程序的安装和管理。要安装Bun,我们需要首先安装Chocolatey。 下面是在Windows上…

    database 2023年5月22日
    00
  • 微服务架构-利用Redis特性进行业务解耦

    背景: 接着上篇文章来,上篇文章讲的是如何利用ApplicationContext的事件机制来达到业务解耦,而且这只能作用在单体应用中。在当下这么盛行的微服务架构中,想要再利用此方案做业务解耦是不可能的了,我们也提到,现在比较流行的解决方案是利用消息队列来完成,例如现在流行的RabbitMQ、RocketMQ、ActiveMQ,Kafka。    当然了,我…

    Redis 2023年4月11日
    00
  • 转 Swoole】用swoole简单实现MySQL连接池

    在传统的网站开发中,比如LNMP模式,由Nginx的master进程接收请求然后分给多个worker进程,每个worker进程再链接php-fpm的master进程,php-fpm再根据当前情况去调用其worker进程然后处理PHP,如果需要MySQL,在与MySQL建立连接,这个时候,如果有1000个请求打过来,就需要与MySQL建立1000个连接。如果请…

    2023年4月13日
    00
  • JDBC连接Oracle数据库常见问题及解决方法

    下面我将为您详细讲解“JDBC连接Oracle数据库常见问题及解决方法”的完整攻略。包括以下几个方面: JDBC连接Oracle数据库的基本方法 首先,我们需要下载并安装Oracle JDBC驱动程序,然后在Java代码中引入该驱动程序。在Java中连接Oracle数据库的方式如下: Class.forName("oracle.jdbc.drive…

    database 2023年5月21日
    00
  • Mysql中DATEDIFF函数的基础语法及练习案例

    Mysql中DATEDIFF函数可以用来计算两个日期之间的天数差。它的基础语法如下: DATEDIFF(date1, date2) 其中,date1和date2是指需要计算天数差值的两个日期,可以是一个列名、常量或一个表达式。函数的返回值是两个日期之间的天数差。 下面是两个DATEDIFF函数的案例示例: 案例一:计算两个固定日期之间的天数差 例如,要计算2…

    database 2023年5月22日
    00
合作推广
合作推广
分享本页
返回顶部