方法一,利用Spring框架管理事务:
DataSourceTransactionManager txManager = new DataSourceTransactionManager();
txManager.setDataSource(jdbcTemplate.getDataSource());
DefaultTransactionDefinition transactionDefinition = new DefaultTransactionDefinition();
TransactionStatus status = null;
try{
status = txManager.getTransaction(transactionDefinition);
//数据库操作开始....
//......
//数据库操作完成
txManager.commit(status);//提交
}catch(Exception e){
//异常处理
//回滚事务
txManager.rollback(status);
}finally{
//do something
}
方法二,使用@Transactional注解声明方式:org.springframework.transaction.annotation.Transactional
在方法体头部声明@Transactional(propagation = Propagation.REQUIRED, readOnly = false, rollbackFor = Exception.class)
//事务传播属性
务,没有的话新建一个(不写的情况下)
开启事务
都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
执行,否则抛出异常
行,否则抛出异常(与Propagation.MANDATORY相反)
法,在其他bean中声明事务,那就用事务.如果其他bean没有声明事务,那就不用事务.
@Transactional(propagation=Propagation.NESTED)//如果没有已定义的Transaction,当前方法新开一个Transaction并在该Transaction中运行。如果存在已定义的Transaction,当前方法在嵌套事务(Nested Transaction)中运行 — 嵌套事务中可以定义储存点,因此可以独立于外部的Transaction而进行rollback。
@Transactional (propagation = Propagation.REQUIRED,readOnly=true) //readOnly=true只读,不能更新,删除
@Transactional (propagation = Propagation.REQUIRED,timeout=30)//设置超时时间
@Transactional (propagation = Propagation.REQUIRED,isolation=Isolation.DEFAULT)//设置数据库隔离级别
@Transactional (rollbackFor = Exception.class)//如果遇到Exception,则回滚当前所有事务