| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- package com.zksy.data.service.impl;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.zksy.common.exception.DbException;
- import com.zksy.data.annotation.XhDataLogRecord;
- import com.zksy.data.domain.po.XcrOtherInfo38;
- import com.zksy.data.domain.response.XcrOtherInfo38Response;
- import com.zksy.data.mapper.XcrOtherInfo38Mapper;
- import com.zksy.data.service.XcrOtherInfo38Service;
- import com.zksy.data.utils.RedisService;
- import com.zksy.data.utils.XhRequestUtil;
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.support.TransactionTemplate;
- import java.util.HashMap;
- import java.util.List;
- import java.util.Vector;
- /**
- * @author Administrator
- * @description 针对表【xcr_other_info_38(科技研发清单表)】的数据库操作Service实现
- * @createDate 2024-10-15 11:09:09
- */
- @Service
- @Slf4j
- public class XcrOtherInfo38ServiceImpl extends ServiceImpl<XcrOtherInfo38Mapper, XcrOtherInfo38>
- implements XcrOtherInfo38Service{
- @Autowired
- private XhRequestUtil xhRequestUtil;
- @Autowired
- private RedisService redisService;
- @Autowired
- private TransactionTemplate transactionTemplate;
- @Override
- @XhDataLogRecord("同步科技研发清单表")
- public void saveDataByUniCode(String address) {
- //模拟从数据库中取数据大约为3000-4000条
- List<String> creditCodes = (List<String>) redisService.getList("creditCodes").get(0);
- Vector<XcrOtherInfo38> toDatabaseList = new Vector<>();
- List<String> inventoryList = List.of("38");
- inventoryList.parallelStream().forEach(inventory -> {
- creditCodes.parallelStream().forEach(creditCode -> {
- HashMap<String, String> requestbodyMap = new HashMap<>();
- requestbodyMap.put("entityCode", creditCode);
- requestbodyMap.put("size", String.valueOf(10));
- requestbodyMap.put("page", String.valueOf(1));
- requestbodyMap.put("inventoryId", inventory);
- try {
- List<XcrOtherInfo38> list = xhRequestUtil.requestXinyonghuanhuai2(requestbodyMap,address,
- XcrOtherInfo38Response.class,
- XcrOtherInfo38.class);
- if(list != null){
- toDatabaseList.addAll(list);
- }
- } catch (Exception e) {
- List<XcrOtherInfo38> list = xhRequestUtil.requestXinyonghuanhuai2(requestbodyMap,address,
- XcrOtherInfo38Response.class,
- XcrOtherInfo38.class);
- if(list != null){
- toDatabaseList.addAll(list);
- }
- }
- });
- log.info("inventorywe为:{}完成",inventory);
- });
- transactionTemplate.execute((s)->{
- try {
- this.remove(null);
- this.saveBatch(toDatabaseList);
- } catch (Exception e) {
- s.setRollbackOnly();
- throw new DbException(e);
- }
- return null;
- });
- log.info("科技研发清单表同步完成");
- }
- }
|