【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

这篇具有很好参考价值的文章主要介绍了【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

⭐️前面的话⭐️

本文已经收录到《Spring框架全家桶系列》专栏,本文将介绍Spring中的事务管理,事务的概念与作用,以及Spring事务的属性和传播机制。

📒博客主页:未见花闻的博客主页
🎉欢迎关注🔎点赞👍收藏⭐️留言📝
📌本文由未见花闻原创,CSDN首发!
📆首发时间:🌴2023年5月16日🌴
✉️坚持和努力一定能换来诗与远方!
💭推荐书籍:📚《无》
💬参考在线编程网站:🌐牛客网🌐力扣🌐acwing
博主的码云gitee,平常博主写的程序代码都在里面。
博主的github,平常博主写的程序代码都在里面。
🍭作者水平很有限,如果发现错误,一定要及时告知作者哦!感谢感谢!



【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)


1.Spring中事务使用方式

1.1Spring事务简介

前面我们已经介绍了如何在Spring环境中整合mybatis完成数据库的增删查改操作,在正常情况下,操作数据库是没有问题的,但是一个业务需要多次操作数据库,并且需要完成修改,插入,删除操作可能会有问题,如转账,其实是有两个步骤,第一步从A账户扣钱,第二步在B账户中加钱。

如果第一步顺利执行后,在执行完成第二步前,程序发生了异常,那就完了,第二个操作就不能够正常执行了,这导致的结果就是,A的钱少了,B的钱没有增多,这种事情客户是完全不能容忍的,所以我们写的程序也是不能够容忍这样的bug。

为了解决这个问题,Spring引入了事务管理的机制,事务的作用就是:

  • 保证执行一组数据库操作的时候,要么全部失败,要不全部成功,即同成功同失败。

那也就是在程序发生异常的时候,回滚所有已经成功数据库操作,这样就算这一次转账失败了,也不会给客户和商家带来损失。

Spring中事务的作用就是:

  • 保证在数据层或业务层执行的一系列数据库操作同成功同失败。

1.2Spring事务的使用

需求: 实现任意两个账户间转账操作

需求微缩: A账户减钱,B账户加钱

为了实现上述的业务需求,我们可以按照下面步骤来实现下:
①:数据层提供基础操作,指定账户减钱(outMoney),指定账户加钱(inMoney)

②:业务层提供转账操作(transfer),调用减钱与加钱的操作

③:提供2个账号和操作金额执行转账操作

④:基于Spring整合MyBatis环境搭建上述操作

为了使用Spring事务,Spring提供了一个平台事务管理器PlatformTransactionManager,使用该管理器,就能够去使用Spring的事务了。

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
commit是用来提交事务,rollback是用来回滚事务,PlatformTransactionManager只是一个接口,Spring还为其提供了一个具体的实现类DataSourceTransactionManager

下面我们就基于该事务管理器DataSourceTransactionManager来实现Spring中的事务。

1.2.1项目准备

具体的步骤不再多说了,创建Maven项目,导入依赖,配置业务层,数据层,单元测试,整合mybatis。

项目结构如下:

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

项目依赖:

    <!--  spring框架依赖 -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>5.3.19</version>
    </dependency>
    <!-- druid数据库连接池依赖 -->
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid</artifactId>
      <version>1.1.16</version>
    </dependency>
    <!--   mybatis依赖-->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.5.6</version>
    </dependency>
    <!--    spring整合mybatis依赖-->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>2.0.7</version>
    </dependency>
    <!--  jdbc依赖  -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>5.3.15</version>
    </dependency>
    <!--  mysql驱动依赖  -->
    <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>8.0.28</version>
    </dependency>
    <!--  lombok依赖 用于快速生成setter getter 和 toString  -->
    <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
    <dependency>
      <groupId>org.projectlombok</groupId>
      <artifactId>lombok</artifactId>
      <version>1.18.26</version>
      <scope>provided</scope>
    </dependency>
    <!-- 整合junit -->
    <!-- https://mvnrepository.com/artifact/junit/junit -->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.13.2</version>
      <scope>test</scope>
    </dependency>
    <!-- spring test环境-->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-test</artifactId>
      <version>5.2.10.RELEASE</version>
    </dependency>

数据表:

create database if not exists transfer;
use transfer;
-- 创建账户表
drop table if exists account;
create table account (
    -- 用户编号uid
                         uid int primary key auto_increment,
    -- 姓名
                         username varchar(32),
    -- 余额
                         money double(8, 2) not null default 0
    );

配置类:

Spring配置类:

@Configuration
@PropertySource("classpath:jdbc.properties")
@ComponentScan("com.transfer.demo")
@Import({MybatisConfig.class, JdbcConfig.class})
@EnableTransactionManagement
public class SpringConfig {
}

数据库配置类,包含数据源等信息的配置:

public class JdbcConfig {
    //驱动
    @Value("${jdbc.driver}")
    private String drive;
    //url
    @Value("${jdbc.url}")
    private String url;
    //账户
    @Value("${jdbc.username}")
    private String username;
    //密码
    @Value("${jdbc.password}")
    private String password;

    /**
     * 配置数据源
     */
    @Bean
    public DataSource getDataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setUrl(url);
        dataSource.setDriverClassName(drive);
        dataSource.setUsername(username);
        dataSource.setPassword(password);
        //设置数据自动提交
        dataSource.setDefaultAutoCommit(true);
        return dataSource;
    }
    @Bean
    public PlatformTransactionManager getTransactionManger(DataSource dataSource) {
        DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
        transactionManager.setDataSource(dataSource);
        return transactionManager;
    }
}

mybatis配置类,使用数据源配置SqlSessionFactory对象工厂,配置xml扫描路径,扫描sql相关注解扫描范围:

public class MybatisConfig {
    /**
     * 配置mybatis
     * @param dataSource 数据库的数据源
     * @return SqlSessionFactoryBean
     */
    @Bean
    public SqlSessionFactoryBean getSqlSessionFactoryBean(DataSource dataSource) {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        //配置数据源
        sqlSessionFactoryBean.setDataSource(dataSource);
        //简化
        sqlSessionFactoryBean.setTypeAliasesPackage("com.transfer.demo.mode");
        //配置所需要扫描到的mapper文件
        sqlSessionFactoryBean.setMapperLocations(new ClassPathResource("mapper/TransferMapper.xml"));
        return sqlSessionFactoryBean;
    }

    /**
     * 配置所对应需要扫描的mapper接口 基于注解编写sql需要设置这个 使用xml文件配置编写sql不需要
     * @return  MapperScannerConfigurer
     */
    @Bean
    public MapperScannerConfigurer getMapperScannerConfigurer() {
        MapperScannerConfigurer configurer = new MapperScannerConfigurer();
        configurer.setBasePackage("com.transfer.demo.dao");
        return configurer;
    }
}

properties配置文件:

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/transfer?useSSL=false&serverTimezone=GMT%2B8&characterEncoding=utf-8
jdbc.username=root
jdbc.password=123456

数据层说明,具体代码以及配置文件sql见博主码云仓库,本项目环境也适应了使用注解进行sql语句的编写:
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
业务层说明:

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

项目环境:
Spring版本:5
MySQL版本:8
Java版本:1.8

1.2.2Spring事务的使用

因为mybatis使用的就是jdbc的事务,所以直接配置jdbc的事务即可。

第一步,配置DataSourceTransactionManager类的Bean,前面在数据库配置当中以及配置好数据源了,直接将数据源配进去即可。
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

第二步,在转账功能上加上@Transactional注解,表示将该方法开启Spring事务,建议加在接口上,降低耦合。

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

第三步,在Spring上启动Spring事务,加上@EnableTransactionManagement注解即可。
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
这样就完成spring事务的设计了,下面我们在转账的两个步骤之间加上一个算术异常,来模拟转账的时候出现异常的情况。

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

单元测试:

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {SpringConfig.class})
public class TransferTest {
    @Autowired
    private TransferService transferService;
    @Test
    public void SelectAllTest() {
        System.out.println(transferService.selectAll());
    }
    @Test
    public void transferMoneyTest() {
        Account user1 = new Account();
        Account user2 = new Account();
        user1.setUid(1);
        user2.setUid(2);
        System.out.println("转账前:");
        System.out.println(transferService.selectByUid(user1.getUid()));
        System.out.println(transferService.selectByUid(user2.getUid()));
        try{
            transferService.transferMoney(user1, user2, 520);
        } catch (ArithmeticException e) {
            System.out.println("转账异常:");
        }
        System.out.println("转账后:");
        System.out.println(transferService.selectByUid(user1.getUid()));
        System.out.println(transferService.selectByUid(user2.getUid()));
    }
}

当前数据库表信息:
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
测试结果:
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
从结果上来看,通过spring事务,虽然转账的第一次数据库操作成功了,但是因为遇到异常,进行了数据库回滚操作,保证了数据的可靠性。

实际上,并不是所有的异常都可以触发回滚操作,默认情况下,程序发生ERROR或者运行时异常会触发回滚操作,其他异常不会触发,当然这些都是可以通过操作@Transactional注解中的参数来设置的。

2.Spring事务角色

在Spring事务中,有两种身份,一种是事务管理员,另外一种是事务协调员:

  • 事务管理员:Spring事务的发起方,在Spring中通常指的是业务层的开启事务的方法。
  • 事务协调员:Spring事务的参与方,在Spring中通常指的是数据层的方法,也可以是业务层的方法。

Spring事务没有开启的时候,数据层的两个修改操作默认情况下在数据库中分别都会开启一个事务。
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
此时,transferMoney方法没有开启事务,会存在以下的可能:

  • 两个数据库操作都执行正常,顺利完成转账。
  • 执行过程中出现意外,第一个数据库操作成功,第二个数据库操作失败,会导致账户A钱变少,B账户钱没到账的情况,这就会造成数据出错。

Spring事务开启后,transferMoney方法就是事务的发起方,即Spring事务管理员,数据层的两个操作虽然需要开启事务,但Spring会告诉数据层的两个方法,让它们加入到Spring的事务当中来,以便保证数据操作同成功同失败,即原子性,数据层的两个方法就是Spring事务协调员。

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

  • transferMoney上添加了@Transactional注解,在该方法上就会有一个事务T。
  • 数据层的outMoney方法的事务T1加入到transfer的事务T中。
  • 数据层的inMoney方法的事务T2加入到transfer的事务T中。
  • 这样就保证他们在同一个事务中,当业务层中出现异常,整个事务就会回滚,保证数据的准确性。

需要保证事务管理是基于DataSourceTransactionManagerSqlSessionFactoryBean使用的是同一个数据源。

3.Spring事务属性

前面我们提到了,并不是所有的异常都会引发回滚操作,如默认情况下遇到IOException事务就不会回滚,如果需要指定其他异常引发回滚或不回滚是可以通过配置@Transactional注解的rollbackFor或者noRollbackFor属性进行配置。

@Transactional注解相关属性如下表:

属性 作用 示例
readOnly 设置是否为只读事务 readOnly=true只读事务
timeout 设置事务超时时间 timeout =-1(永不超时,默认)
rollbackFor 设置事务回滚异常(class) rollbackFor = NullPointException. class
rollbackForClassName 设置事务回滚异常(String) 同上格式为字符串
noRollbackFor 设置事务不回滚异常(class) noRollbackFor = NullPointException. class
noRollbackForClassName 设置事务不回滚异常(String) 同上格式为字符串
isolation 设置事务隔离级别 isolation = Isolation. DEFAULT
propagation 设置事务传播行为 -

说明:

  • readOnly:true只读事务,false读写事务,增删改要设为false,查询设为true。
  • timeout:设置超时时间单位秒,在多长时间之内事务没有提交成功就自动回滚,-1表示不设置超时时间。
  • rollbackFor:当出现指定异常进行事务回滚,不影响错误和运行时异常进行事务回滚。
  • noRollbackFor:当出现指定异常不进行事务回滚,可以将某种会引发回滚的异常设置为不回滚。
  • rollbackForClassName等同于rollbackFor,只不过属性为异常的类全名字符串。
  • noRollbackForClassName等同于noRollbackFor,只不过属性为异常的类全名字符串。
  • isolation设置事务的隔离级别:
    • DEFAULT :默认隔离级别, 会采用数据库的隔离级别
    • READ_UNCOMMITTED : 读未提交
    • READ_COMMITTED : 读已提交
    • REPEATABLE_READ : 重复读取
    • SERIALIZABLE: 串行化

重点属性就是rollbackFor属性,设置遇到哪一些异常就会回滚事务,默认情况是遇到Error异常RuntimeException异常及其子类就会自动回滚。

示例1,将运行时异常设置为不回滚。

@Transactional(noRollbackFor = {ArithmeticException.class})

示例2,将非运行时异常和非错误的异常设置为引发回滚。

@Transactional(rollbackFor = {IOException.class})

4.Spring事务的传播机制

4.1Spring事务传播机制

前面我们说过Spring事务中,开启事务的时候,事务管理员所在方法中所有的其他事务默认情况下都会加入该事务,成为事务协调员,但是有时候并不需要将里面所有的事务都加入到事务管理员所开启的事务当中,为了解决这种情况,我们可以调整Spring中事务的传播机制,Spring中传播机制的种类有如下几种:

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

REQUIRED: 需要事务,外部存在事务融入当前事务,外部没有事务,开启新的事务。
SUPPORTS: 支持事务,外部存在事务融入当前事务,外部没有事务,不开启新的事务。
REQUIRES_NEW: 每次开启新的事务,如果外部存在事务外部事务挂起,开启新的事务运行,运行结束后回到外部事务。
NOT_SUPPORTED: 不支持事务,如果外部存在事务外部事务挂起,以非事务方式运行。
NEVER: 不支持事务,存在事务报错。
MANDATORY: 强制事务,没有事务报错。
NESTED: 嵌套事务,数据库不支持。

通过设置@Transactional注解中的propagation属性就可以完成Spring事务传播机制的修改。

前面实现了一个转账的案例,在实际的转账的过程中都会存在转账记录,对于转账记录,无论转账是否成功都需要记录,如果使用默认的事务传播机制,一旦转账失败,转账记录就无法存入到数据库当中。所以对于日志记录的事务需要新建一个事务单独运行,需要采用REQUIRES_NEW的事务传播机制。

4.2转账日志记录案例实现

下面我们在转账的基础上加上这样一个记录日志的要求,并实现。

需求:记录转账过程中的转账记录,不论成功还是失败都需要记录,不影响转账操作的原子性。
解决方案:调整日志记录的事务传播机制,当转账事务开启的时候,不加入该事务。

第一步,准备一张表,用来记录转账日志信息,设计如下:
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

lid表示日志的编号,content表示转账细节信息,state表示转账是成功还是失败。

建表语句如下:

use transfer;
-- 创建日志表
drop table if exists account_log;
create table account_log (
    -- 日志id
    lid int primary key auto_increment,
    -- 日志内容
    content varchar(128),
    -- 状态
    state varchar(16)
);

insert into account_log values(null, '测试', '成功');

第二步,编写数据层接口,至少有日志的插入和查询方法,基于注解就直接在数据层写sql即可,配置文件实现,需要另外再写一个配置文件用来写sql,不论哪种都要保证mybatis都能够扫描到。
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
对应业务层实现:

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

第三步,编写日志插入和查询操作的业务层方法,在转账操作中加入转账日志记录功能,因为不论转账失败还是成功都需要记录,所以日志插入可以写在finally中。

为了方便判断转账操作是否成功,我们将转账的两部数据操作放入到同一个try中,然后使用一个变量flag来表示转账操作是否成功,如果执行完第二步转账操作没有出现异常,就将flag置为true

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

这样还不够,在存转账日志的时候,因为不论转账成功还是失败都需要存入转账记录,那么日志插入操作的事务必须单独开启,需要在插入日志的service方法设置事务传播属性为REQUIRES_NEW
【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

第四步,编写单元测试代码并验证。

单元测试代码如下,就不解释了,按照自己的思路写个验证程序即可。

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)
测试结果:

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)

5.总结

知识点1:@EnableTransactionManagement
名称 @EnableTransactionManagement
类型 配置类注解
位置 配置类定义上方
作用 设置当前Spring环境中开启注解式事务支持
知识点2:@Transactional
名称 @Transactional
类型 接口注解 类注解 方法注解
位置 业务层接口上方 业务层实现类上方 业务方法上方
作用 为当前业务层方法添加事务(如果设置在类或接口上方则类或接口中所有方法均添加事务)
  1. @Transactional 注解只能用在public 方法上,如果用在protected或者private的方法上,不会报错,但是该注解不会生效。
  2. @Transactional注解只能回滚非检查型异常,具体为RuntimeException及其子类和Error子类,可以从Spring源码的DefaultTransactionAttribute类里找到判断方法rollbackOn。
  3. 使用rollbackFor 属性来定义回滚的异常类型,使用 propagation 属性定义事务的传播行为。如: 回滚Exception类的异常,事务的传播行为支持当前事务,当前如果没有事务,那么会创建一个事务。
  4. @Transactional注解不能回滚被try{}catch() 捕获的异常。
  5. @Transactional注解只能对在被Spring 容器扫描到的类下的方法生效。

其实Spring事务的创建也是有一定的规则,对于一个方法里已经存在的事务,Spring 也提供了解决方案去进一步处理存在事务,通过设置@Tranasctional的propagation 属性定义Spring 事务的传播规则。


觉得文章写得不错的老铁们,点赞评论关注走一波!谢谢啦!

【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)文章来源地址https://www.toymoban.com/news/detail-469535.html

到了这里,关于【Spring全家桶系列】Spring中的事务管理(基于注解完成实现)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • spring事务管理详解和实例(事务传播机制、事务隔离级别)

    目录 1 理解spring事务 2 核心接口 2.1 事务管理器 2.1.1 JDBC事务 2.1.2 Hibernate事务 2.1.3 Java持久化API事务(JPA) 2.2 基本事务属性的定义 2.2.1 传播行为 2.2.2 隔离级别 2.2.3 只读 2.2.4 事务超时 2.2.5 回滚规则 2.3 事务状态 3 编程式事务 3.1 编程式和声明式事务的区别 3.2 如何实现编程式

    2024年02月06日
    浏览(43)
  • 【Spring】Spring的事务管理

    Spring的事务管理简化了传统的事务管理流程,并且在一定程度上减少了开发者的工作量。 1.1 事务管理的核心接口 在Spring的所有JAR包中包含一个名为Spring-tx-4.3.6.RELEASE的JAR包,该包就是Spring提供的用于事务管理的依赖包。在该JAR包的org.Springframework.transaction包中有3个接口文件:

    2024年02月03日
    浏览(96)
  • Spring 事务管理

    目录 1. 事务管理 1.1. Spring框架的事务支持模型的优势 1.1.1. 全局事务 1.1.2. 本地事务 1.1.3. Spring框架的一致化编程模型 1.2. 了解Spring框架的事务抽象(Transaction Abstraction) 1.2.1. Hibernate 事务设置 1.3. 用事务同步资源 1.3.1. 高级同步方式 1.3.2. 低级同步方式 1.3.3.TransactionAwareDataSo

    2024年02月13日
    浏览(46)
  • Spring的事务管理

    1、事务的回顾 【1】事务的定义 是数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作,这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行;事务是一组不可再分割的操作集合 【2】事务的ACID原则 事务具有4个基本特性:原子性、一致性

    2023年04月16日
    浏览(75)
  • Spring之事务管理

    事务是数据库操作最基本单位,要么都成功,要么都失败。 原子性 一致性 隔离性 持久性。 Spring定义了7种传播行为: 传播属性 描述 REQUIRED 如果有事务在运行,当前的方法就在这个事务内运行,否则,就启动一个新的事务,并在自己的事务内运行 REQUIRED_NEW 当前的方法必须

    2024年02月13日
    浏览(67)
  • Spring使用@Transactional 管理事务,Java事务详解。

    B站视频:https://www.bilibili.com/video/BV1eV411u7cg 技术文档:https://d9bp4nr5ye.feishu.cn/wiki/HX50wdHFyiFoLrkfEAAcTBdinvh 简单来说事务就是一组对数据库的操作 要么都成功,要么都失败。 事务要保证可靠性,必须具备四个特性:ACID。 A:原子性:事务是一个原子操作单元,要么完全执行,要么

    2024年02月11日
    浏览(31)
  • 【掌握Spring事务管理】深入理解事务传播机制的秘密

    🎉🎉🎉 点进来你就是我的人了 博主主页: 🙈🙈🙈 戳一戳,欢迎大佬指点! 欢迎志同道合的朋友一起加油喔 🤺🤺🤺 目录 1.Spring 中事务的实现方式 1.1 Spring 编程式事务 (了解) 1.2 Spring 声明式事务 ( @Transactional ) 【异常情况一】(自动回滚成功) 【异常情况二】(自动回滚失效

    2024年02月10日
    浏览(46)
  • 【Spring教程21】Spring框架实战:Spring事务简介、AOP事务管理、代码示例全面详解

    欢迎大家回到《Java教程之Spring30天快速入门》,本教程所有示例均基于Maven实现,如果您对Maven还很陌生,请移步本人的博文《如何在windows11下安装Maven并配置以及 IDEA配置Maven环境》,本文的上一篇为《AOP(面对切面编程)知识总结》 事务作用:在数据层保障一系列的数据库

    2024年02月04日
    浏览(46)
  • 【MySQL系列】MySQL的事务管理的学习(一)_ 事务概念 | 事务操作方式 | 事务隔离级别

    「前言」文章内容大致是MySQL事务管理。 「归属专栏」MySQL 「主页链接」个人主页 「笔者」枫叶先生(fy) 事务的概念 MySQL事务是指一系列的数据库操作(一组 DML 语句),这些操作要么全部成功执行,要么全部失败回滚。事务的目的是确保数据库的一致性和完整性 事务就是要

    2024年02月09日
    浏览(35)
  • Spring 事务管理详解及使用

    ✅作者简介:2022年 博客新星 第八 。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏:SSM 框架从入门到精通 ✨特色专栏:国学周更-心性养成之路 🥭本文内容:一文吃透 Spring 中

    2024年01月20日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包