mybatis中的事务处理(commit)

mybatis单独使用时,使用SqlSession来处理事务,打开会话,事务处理开始,增删改操作时要执行commit操作,事物提交后,关闭会话,事物结束。

@Test
    public void insertUserTest() throws Exception {
        // 1、读取配置文件
        String resource = "SqlMapConfig.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        // 2、根据配置文件创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()
                .build(inputStream);
        // 3、SqlSessionFactory创建SqlSession
        //如果sqlsessionFactory.opensession(true)参数是布尔值,如果设置为true,就不需要commit提交事务了
        SqlSession sqlSession = sqlSessionFactory.openSession();//openSession打开会话,事务处理开始
        // 4、SqlSession执行statement,并返回映射结果
        //构建user参数,没有赋值的属性采取默认值
        User user = new User();
        user.setUsername("东哥1");
        user.setAddress("清河宝盛西里");

        // 第一个参数:statement的id,建议:namespace.statementId(确保唯一)
        // 第二个参数:入参的值,它的类型要和映射文件中对应的statement的入参类型一致
        sqlSession.insert("insertUser", user);

        //切记:增删改操作时,要执行commit操作
        sqlSession.commit();

        // 5、关闭SqlSession
        sqlSession.close();
    }
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
SpringBoot整合MyBatis可以使用Spring的事务管理机制来实现事务的回滚和提交。 在SpringBoot,我们可以通过在方法上使用`@Transactional`注解来声明事务,用于标识需要进行事务管理的方法。当方法执行时,如果出现异常导致方法终止,则事务管理器会自动回滚事务,将所有数据库操作都撤销到事务开始前的状态。如果方法执行成功,则事务管理器会将所有数据库操作统一提交。 事务的回滚和提交是由Spring的事务管理器来实现的。Spring提供了几种常用的事务管理器实现,可以根据具体的项目需求选择合适的事务管理器。 其,如果要使用MyBatis的事务管理器,需要在SpringBoot的配置文件(application.properties或application.yml)进行配置。具体配置项如下: ``` # 指定事务管理器类型为JDBC spring.datasource.type=org.apache.tomcat.jdbc.pool.DataSource # 开启事务支持 spring.datasource.tomcat.initSQL=getLockTimeout spring.datasource.url=jdbc:mysql://localhost:3306/mydb spring.datasource.username=root spring.datasource.password=root # 配置MyBatis的Mapper接口 mybatis.type-aliases-package=com.example.model mybatis.mapper-locations=classpath:mapper/*.xml # 配置事务管理器 mybatis.mapper-locations=classpath:mapper/*.xml ``` 配置完成后,就可以在需要进行事务管理的方法上添加`@Transactional`注解,即可实现事务的自动回滚和提交。 需要注意的是,事务的回滚和提交是根据方法的异常情况来决定的,只有在方法抛出运行时异常或Error时才会触发事务的回滚。如果在方法抛出的是受检异常(如IOException),则不会触发事务的回滚。如果需要手动触发事务的回滚,可以在方法捕获异常,并调用`TransactionAspectSupport.currentTransactionStatus().setRollbackOnly()`方法来设置事务的回滚状态。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值