事务注释@Transactional

来源:互联网 发布:算法艺术与信息学竞赛 编辑:程序博客网 时间:2024/06/04 19:09

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();}}
原创粉丝点击