事务不生效
业务场景:最近遇到一个业务复杂的项目,做POI的导入功能,由于关联表格较多,需要插入多张表用到多个insert 基于Dao接口。起初是在service层处理加上@transication注解!结果发现由于嵌套的方法过多,无法做到回滚(只要有一个方法发生错误则整个事件都不生效)。最后将事务放在Controller层,基于基于手动提交事务,伪代码如下:
@Autowired
private PlatformTransactionManager manger;
@RequestMapping
public String toImort(){
DefaultTransactionDefinition transaction = new DefaultTransactionDefinition();
transaction.setPropagationBehaviorName(TransactedDefinition.PROPAGTION_REQUIRED);
TransactionStatus status = manager.geyTransaction(transaction);
/**
* 业务处理
*
*/
插入方法:saveData(data);
manager.commit(status);//手动提交
try{
}catch(){
manager.rollback(status);//回滚
}
}