多个service嵌套事务不生效@transaction无效,解决办法

事务不生效

业务场景:最近遇到一个业务复杂的项目,做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);//回滚
	}




}

©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页