事务注释@Transactional

1.propagation 定义事务的传播行为

    progagation.required:如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这事务中,这个是最常见的选择
    propagation.supports:支持当前事务,如果当前没有事务,就以非事务的方式执行
    propagation.required_new:新建事务,如果当前存在事务,把当前事务挂起
    propagation.not_supported:以非事务的方式执行操作,如果当前存在事务就把当前事务挂起
    propagation.mandatory:使用当前事务,如果当前没有事务,就抛出异常
    propagation.never:以非事务的方式执行,如果当前存在事务,则抛出异常
    propagation.nested:如果当前存在事务,则在嵌套事务中执行,如果当前没有事务,则执行与required类似的操作

2.isolation 定义事务隔离行为

    isolation.default:使用数据库默认隔离行为,与具体数据库采用的隔离行为相关,如:oracle采用READ_COMMITED
    isolation.read_uncommited:这是事务最低的隔离级别,它允许别的一个事务可以看到这个事务未提交的数据,这个隔离级别会产生脏读,不可重复读与幻读
    isolation.read_commited:保证一个事务修改的数据提交后才能被另外一个事务读取,另外一个事务不能读取该事务未提交的数据。这种事务隔离级别可以避免脏读出现,但是可能会出现不可重复读和幻读
    propagation.serializable:这个花费最高代价但是最可靠的事务隔离级别,事务被处理为顺序执行,除了防止脏读,不可重复读外,还避免了幻读

3.手动事务

分批提交,保证一次性事务提交的数据量在1万以内。
public class MyTranscationBO {

     public void methodA(){
 Transactiontamplate tx = new Transactiontamplate ();
try{
    int max= 10000; // 一次性事务提交的阈值
    for (int i = 0; i < 100000; i++) {
       if (i % max== 0) {
           if (i > 0) {
               tx.commit();
}
           tx.begin();
       }
        dao.save(……);
                    }
             tx.commit();
} catch(Exception e){
     tx.rollback();
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值