事务的实现方式

事务是什么时候提交的

@Transactional  
public void xxx() {  
    ...  
}

上次我看过一篇文章,事务注解也是基于aop实现的,会在这个方法的最后一行执行完后,才会进行commit统一入库;

目录

一:Transactional 注解

二:抽取事务管理类

2.1提交事务管理类

2.2提交sqlsession类

2.3 工具类util创建事务

2.4 实例调用

2.5额外扩展


一:Transactional 注解

@Transactional  
public void xxx() {  
    ...  
}

使用改事务后,xxx执行数据库相关操作,代码走完之后,进行事务的提交,中途sql报错不会进行事务提交的;

要是方法xxx调用另一个方法xxxx,也有默认的事务隔离级别,(xxxx别开启事务了,保持在一个事务里面最好,以防数据出现混乱)

二:抽取事务管理类

使项目所有数据库操作,由事务管理类进行执行sql、提交事务、并关闭

2.1提交事务管理类

//事务提交控制类
public class TxstatusBatch implements Closeable{
    
    private TransactionStatus status;//可以理解为一个transaction注解

    private TransactionDefinition def;//事务的隔离级别

    private PlatformTransactionManager txManager;

    private BatchSqlSession batchSqlSession;//控制提交sql


    //构造方法,构建一个完整的事务处理机制,
    protected TxstatusBatch(PlatformTransactionManager txManager,TransactionDefinition def,BatchSqlSession batchSqlSession){

        this.txManager = txManager;
        this.def = def;
        //开启一个事务
        this.status = this.txManager.getTransaction(def);

        this.batchSqlSession = batchSqlSession;
    }

    
    //事务提交
    public void commit(){
        this.txManager.commit(this.status);
        //事务提交之后,之前的status事务就结束了,status.isCompleted()
        //所以需要重新开启一个事务
        this.status = this.txManager.getTransaction(this.def);
    }


    @Override
    public void close(){
        if(!this.status.isCompleted()){
            this.txManager.rollback(this.status);
        }
    }


    //执行sql,可以参考jdbc执行流程以及mybatis怎么执行的sql,下面会有备注,此处忽略
    public void select(String statement,Object parameter,ResultHandler handle){
        this.batchSqlSession.select(statement,parameter,handler);
    }

    public int insert(String statement,Object parameter){
        return  this.batchSqlSession.insert(statement,parameter);
    }

    public int update(String statement,Object parameter){
        return this.batchSqlSession.update(statement,parameter);
    }

    public int delete(String statement,Object parameter){
        return this.batchSqlSession.delete(statement,parameter);
    }

    public int[] insertList(String statement,List<?> parameter){
        return this.batchSqlSession.insertList(statement,parameter);
    }

    public int[] updateList(String statement,List<?> parameter){
        return this.batchSqlSession.updateList(statement,parameter);
    }

}

2.2提交sqlsession类

public class BatchSqlSession{

    private Sqlsession sqlsession;

    protected BatchSqlSession(Sqlsession sqlsession){
        this.sqlsession = sqlsession;
    }

    public void select(String statement, Object parameter,@SuppressWarnings("rawtypes") ResultHandler handler){
        this.sqlsession.select(statement, parameter, handler);
    }

    public int insert(String statement, Object parameter){
        return this.sqlsession.insert(statement, parameter);
    }

    public int update(String statement, Object parameter){
        return this.sqlsession.update(statement, parameter);
    }

    public int delete(String statement, Object parameter){
        return this.sqlsession.delete(statement, parameter);
    }

    public int[] insertList(String statement, List<?> parameter){
        int len = parameter.size();
        int[] rets = new int[len];
        for(int i = 0;i < len; i++){
            rets[i]  = this.sqlsession.insert(statement, parameter.get(i));
        }
        return rets;
    }

    public int[] updatetList(String statement, List<?> parameter){
        int len = parameter.size();
        int[] rets = new int[len];
        for(int i = 0;i < len; i++){
            rets[i]  = this.sqlsession.update(statement, parameter.get(i));
        }
        return rets;
    }

}

2.3 工具类util创建事务

@Component
public class TxToolBatch{
    
    @Autowired
    private SqlSessionFactory sqlSessionFactory;

    @Autowired
    private ApplicationContext ac;

    @Autowired
    private PlatformTransactionManager txManager;

    @Bean
    public BatchSqlSession getBatchSqlSession(){
        SqlSessionTemplate sqlSession = new SqlSessionTemplate(sqlSessionFactory,ExecutorType.BATCH);
        return new BatchSqlSession(sqlSession );
    }

    //开启一个事务,默认的事务传播行为
    public TxStatusBatch starttrans(){
        return new TxStatusBatch(txManager, new DefaultTransactionDefinition(TransactionDefinition.PROPAGATION_REQUIRES_NEW), ac.getBean(BatchSqlSession.class));
    }

}

2.4 实例调用

public void xxx() {  
     //略。。。

    try(TxStatusBatch tx = txToolBatch.starttrans()){
        //数据库相关sql操作,略,。。。
        
        //提交事务
        tx.commit();
    }catch(Exception e){
        //打印相关异常信息,并抛出异常
    }
}

2.5额外扩展

try(){}作用,参考链接:点击了解

mybatis执行sql等源码解析。参考链接:点击了解

jdbc执行sql步骤重温,参考链接:点击了解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值