From 62654cb7d3e23074278c7c061bef8f6cbee90d73 Mon Sep 17 00:00:00 2001
From: ludc
Date: 星期五, 10 十一月 2023 09:48:21 +0800
Subject: [PATCH] 修改历史数据导入时限制单次导入通过配置做限制,开启多线程分批并行执行insert,注解开启事务回滚失效,对象方式开启事务实现手动提交事务,异常回滚事务

---
 Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/MdmProductCodeServiceImpl.java |   22 +++++++++++++++++++++-
 1 files changed, 21 insertions(+), 1 deletions(-)

diff --git a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/MdmProductCodeServiceImpl.java b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/MdmProductCodeServiceImpl.java
index f58d927..5c2fa06 100644
--- a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/MdmProductCodeServiceImpl.java
+++ b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/MdmProductCodeServiceImpl.java
@@ -36,7 +36,10 @@
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.context.annotation.Lazy;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.TransactionStatus;
 import org.springframework.transaction.annotation.Transactional;
+import org.springframework.transaction.support.DefaultTransactionDefinition;
+import org.springframework.transaction.support.TransactionTemplate;
 import org.springframework.util.CollectionUtils;
 
 import javax.annotation.Resource;
@@ -80,6 +83,10 @@
 	 */
 	@Autowired
 	private FormulaServiceImpl formulaService;
+
+	// 娉ㄥ叆浜嬪姟绠$悊鍣�
+	@Autowired
+	private TransactionTemplate transactionTemplate;
 
 	@Override
 	@Transactional(rollbackFor = Exception.class)
@@ -265,6 +272,10 @@
 				if(!CollectionUtils.isEmpty(editCodeDOs)){
 					codeAllCodeService.updateBatchById(editCodeDOs);
 				}
+				// 鑾峰彇浜嬪姟瀹氫箟
+				DefaultTransactionDefinition def = new DefaultTransactionDefinition();
+				// 寮�濮嬩簨鍔�
+				TransactionStatus status = transactionTemplate.getTransactionManager().getTransaction(def);
 				if(!CollectionUtils.isEmpty(addCodeDOs)){
 					Map<String, String> statusMap = addCodeDOs.stream().collect(Collectors.toMap(s -> s.getOid(), s -> s.getLcStatus()));
 					addCodeDOs.stream().filter(s -> StringUtils.equalsIgnoreCase("codeallcode",s.getBtmname())).forEach(s -> {
@@ -303,10 +314,19 @@
 					if(takeBack.size()>0){
 						codeAllCodeService.updateBatchById(takeBack);
 					}
+
 					codeAllCodeService.saveBatch(addCodeDOs);
 				}
 
-				mdmEngineService.insertBatchByType(dataCBOList.get(0).getBtmname(),dataCBOList);
+				try {
+					mdmEngineService.insertBatchByType(dataCBOList.get(0).getBtmname(),dataCBOList);
+					// 鎻愪氦浜嬪姟
+					transactionTemplate.getTransactionManager().commit(status);
+				}catch (Exception e){
+					// 鍑虹幇寮傚父鏃跺洖婊氫簨鍔�
+					transactionTemplate.getTransactionManager().rollback(status);
+				}
+
 			}
 			return codeList;
 		}else {

--
Gitblit v1.9.3