Spring事务分析

一、Spring事务概念

1.1 数据库事务特性

1.2 事务隔离级别

mysql通过间隙锁,解决了幻读问题

二、Spring事务使用

2.1 Spring事务相关API

2.2 编程式事务 

public class SpringTransactionExample {

    private static String url = "jdbc:mysql://localhost:3306/spring_transaction?useSSL=false&characterEncoding=utf-8&autoReconnect=true";
    private static String user = "root";
    private static String password = "root";

    public static void main(String[] args) {
        // 获取数据源
        final DataSource ds = new DriverManagerDataSource(url, user, password);
        // 编程式事务
        final TransactionTemplate template = new TransactionTemplate();
        // 设置事务管理器
        template.setTransactionManager(new DataSourceTransactionManager(ds));

        template.execute(new TransactionCallback<Object>() {
            @Override
            public Object doInTransaction(TransactionStatus transactionStatus) {
                Connection conn = DataSourceUtils.getConnection(ds);
                Object savePoint = null;
                try {
                    {
                        // 插入
                        PreparedStatement prepare = conn.prepareStatement("insert into person(id, name) values (?, ?)");
                        prepare.setString(1, "1");
                        prepare.setString(2, "1111");
                        prepare.executeUpdate();
                    }

                    // 设置保存点,回滚的化,不会回滚保存点之前的操作
                    savePoint = transactionStatus.createSavepoint();
                    {
                        // 插入
                        PreparedStatement prepare = conn.prepareStatement("insert into person(id, name) values (?, ?)");
                        prepare.setString(1, "2");
                        prepare.setString(2, "222");
                        prepare.executeUpdate();
                    }

                    {
                        // 更新
                        PreparedStatement prepare = conn.prepareStatement("update person set name = ? where id = ?");
                        prepare.setString(1, "jak");
                        prepare.setInt(2, 6);
                        prepare.executeUpdate();

                        // 模拟异常
                        int i = 1 / 0;
                    }
                } catch (SQLException e) {
                    e.printStackTrace();
                } catch (Exception e) {
                    System.out.println("更新失败");
                    if (savePoint != null) {
                        // 回滚到保存点
                        transactionStatus.rollbackToSavepoint(savePoint);
                    } else {
                        transactionStatus.setRollbackOnly();
                    }
                }
                return null;
            }
        });
    }
}

只回滚了savepoint后面的数据,第一条插入的数据,保留着。

2.3 声明式事务

2.4 事务传播机制

传播属性

常用事务传播机制

Spring 事务操作、 视频教程Spring事务源码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
动态分析Spring事务可以通过以下几个步骤来实现: 1. 首先,了解Spring事务的底层机制。根据引用,Spring事务是通过代理对象对数据库的操作进行事务处理的。这意味着我们可以通过对代理对象的分析来了解事务的执行流程和行为。 2. 其次,使用合适的工具或方法来进行动态分析。有很多工具可以用于动态分析Spring事务,比如基于AOP的日志记录、调试器和性能分析工具等。这些工具可以帮助我们跟踪事务的执行过程、记录事务的日志和性能数据等。 3. 在动态分析的过程中,我们可以关注以下几个方面来获取更多信息: a. 事务的执行流程:通过分析事务的开始、提交和回滚等关键点,可以了解事务的执行流程,以及在不同情况下事务是如何被处理的。 b. 事务的隔离级别:通过分析事务的隔离级别设置,可以了解事务在并发环境下的行为和影响。 c. 事务的传播行为:通过分析事务的传播行为设置,可以了解事务在嵌套调用和并发执行等场景下的行为。 d. 事务的异常处理:根据引用,Spring框架默认只在发生不受控异常时才进行事务回滚。通过分析事务的异常处理机制,可以了解事务在不同异常情况下的处理方式。 4. 最后,根据动态分析的结果,可以对Spring事务进行优化或问题排查。例如,如果发现事务执行时间过长,可以通过优化数据库查询或调整事务的隔离级别来提高性能。 总之,通过了解Spring事务的底层机制,并使用合适的工具和方法进行动态分析,我们可以深入了解Spring事务的执行流程、隔离级别、传播行为和异常处理等方面的信息,以便进行优化和问题排查。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值