r2dbc事务处理

简介: r2dbc事务处理

劳动创造了人本身。——恩格斯

官方demo

https://github.com/spring-projects/spring-data-examples/blob/main/r2dbc/example/src/main/java/example/springdata/r2dbc/basics/TransactionalService.java

/*
 * Copyright 2019-2021 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package example.springdata.r2dbc.basics;
import lombok.NonNull;
import lombok.RequiredArgsConstructor;
import reactor.core.publisher.Mono;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;
/**
 * @author Oliver Drotbohm
 */
@Component
@RequiredArgsConstructor
class TransactionalService {
  private final @NonNull CustomerRepository repository;
  /**
   * Saves the given {@link Customer} unless its firstname is "Dave".
   *
   * @param customer must not be {@literal null}.
   * @return
   */
  @Transactional
  public Mono<Customer> save(Customer customer) {
    return repository.save(customer).map(it -> {
      if (it.firstname().equals("Dave")) {
        throw new IllegalStateException();
      } else {
        return it;
      }
    });
  }
}

可以看到是支持Transactional

当然我们可以手动回滚事务,配置:

import io.r2dbc.spi.ConnectionFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.r2dbc.connection.R2dbcTransactionManager;
import org.springframework.transaction.ReactiveTransactionManager;
import org.springframework.transaction.reactive.TransactionalOperator;
@Configuration
public class R2dbcConfig {
    @Bean
    public ReactiveTransactionManager reactiveTransactionManager(ConnectionFactory connectionFactory) {
        return new R2dbcTransactionManager(connectionFactory);
    }
    @Bean
    public TransactionalOperator transactionalOperator(ReactiveTransactionManager txm) {
        return TransactionalOperator.create(txm);
    }
}

使用:

@Resource
private TransactionalOperator transactionalOperator;
@Test
void test() {
    var user = new User();
    user.setId(1L);
    user.setName("test");
    transactionalOperator.execute(transactionStatus -> {
                transactionStatus.setRollbackOnly();
                return r2dbcEntityOperations.insert(user)
                        .thenMany(userRepository.findAll());
            }).as(StepVerifier::create)
            .expectNextMatches(e -> true).verifyComplete();
}
相关文章
|
2月前
|
Java
r2dbc事务处理
r2dbc事务处理
87 0
|
存储 关系型数据库 MySQL
详解 Mysql 分布式事务 XA(跨数据库事务)
详解 Mysql 分布式事务 XA(跨数据库事务)
|
存储 SQL 容灾
TDSQL XA的事务隔离级别
本文是我最初于2017年发表在我的个人微信公众号里面,现发布在这里。 1.1. 概述 TDSQL XA全局事务(global transaction)是指用户客户端连接到TDSQL XA分布式数据库系统后发起和执行的事务,也就是TDSQL XA处理的分布式事务。一个全局事务可能会写入数据到多个后端mysql 数据库实例,每个实例上面的本地事务都是这个全局事务的事务分支(transaction branch)。客户端发起全局事务提交时,运行在TDSQL XA的网关模块中的全局事务管理器会控制该事务访问的所有后端mysql数据库实例完成两阶段提交。 TDSQL XA的全局事务的隔离级别最高可以
209 0
|
数据库
EF 事务(非分布式事务)
在EF 中怎么使用事务? 这个问题纠结了我好久,直到有人跟我一起讨论,我和同事一起讨论查资料。 查的好多资料都是使用 TransactionScope,用 TransactionScope 可处理分布式事务。
1445 0
|
关系型数据库 MySQL 数据库
EF Core利用Transaction对数据进行回滚保护
What? 首先,说一下什么是EF Core中的Transaction Transaction允许以原子方式处理多个数据库操作,如果事务已提交,则所有操作都应用于数据库,如果事务回滚,则没有任何操作应用于数据库。
1848 0
|
SQL 数据库 Windows