Aop-spring 注解@Transactional()事务管理

    @Transactional()//可以使用这个mybatis注解  或者自定义AopSpringAspect方法    
    public void runAspect(){
        //事务里面不要用try catch 如果使用了一定要手动回滚
        user.create("刘良","mm","江西");
        List<Userinfo> userinfos =  user.findAll();
        int uid = 0;
        for(Userinfo info : userinfos){
            if(info.getUsername().equals("刘良")){
                uid = info.getUid();
            }
        }
        System.out.println("用户信息:" + user.findById(uid));
        int m = 1/0;//模拟异常,回滚提交
        user.update("李白","ww","麻花",uid);
        System.out.println("用户修改:" + user.findById(uid));
//        user.delete(uid);
    }

@Transactional使用


1.只能使用在public方法或者类上,不建议使用在接口上
2.不要在内部使用try catch.使用了内部自己写回滚逻辑 
参数设置
value 和 transactionManager
当配置了多个事务管理器时,可以使用该属性指定选择哪个事务管理器

propagation:

在默认的代理模式下,只有目标方法由外部调用,才能被 Spring 的事务拦截器拦截(就是说在同一个类,不同方法就算是加上REQUIRES_NEW也不会新创建一个事务,要用两个类)
Propagation.REQUIRED 如果当前存在事务,则加入该事务,如果当前不存在事务,则创建一个新的事务。(默认值)
Propagation.SUPPORTS 如果当前存在事务,则加入该事务;如果当前不存在事务,则以非事务的方式继续运行。
Propagation.MANDATORY 如果当前存在事务,则加入该事务;如果当前不存在事务,则抛出异常。
Propagation.REQUIRES_NEW 重新创建一个新的事务,如果当前存在事务,暂停当前的事务。
Propagation.NOT_SUPPORTED 以非事务的方式运行,如果当前存在事务,暂停当前的事务。
Propagation.NEVER 以非事务的方式运行,如果当前存在事务,则抛出异常。
Propagation.NESTED 和 Propagation.REQUIRED 效果一样。
isolation :
     Isolation.DEFAULT 使用底层数据库默认的隔离级别。(默认)
     Isolation.READ_UNCOMMITTED
     Isolation.READ_COMMITTED
     Isolation.REPEATABLE_READ
     Isolation.SERIALIZABLE
timeout :事务的超时时间,默认值为-1。如果超过该时间限制但事务还没有完成,则自动
readOnly :指定事务是否为只读事务,默认值为 false;为了忽略那些不需要事务的
rollbackFor :用于指定能够触发事务回滚的异常类型,可以指定多个异常类型。
noRollbackFor :抛出指定的异常类型,不回滚事务,也可以指定多个异常类型。

猜你喜欢

转载自blog.csdn.net/qq_35418518/article/details/89069524