XcrMainFinancialStatementsServiceImpl.java 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package com.zksy.data.service.impl;
  2. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  3. import com.zksy.data.domain.po.XcrMainFinancialStatements;
  4. import com.zksy.data.domain.response.XcrMainFinancialStatementsResponse;
  5. import com.zksy.data.service.XcrMainFinancialStatementsService;
  6. import com.zksy.data.mapper.XcrMainFinancialStatementsMapper;
  7. import com.zksy.data.utils.RedisService;
  8. import com.zksy.data.utils.XhRequestUtil;
  9. import lombok.extern.slf4j.Slf4j;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.stereotype.Service;
  12. import org.springframework.transaction.annotation.Transactional;
  13. import java.util.List;
  14. import java.util.Vector;
  15. /**
  16. * @author 邵洋
  17. * @description 针对表【xcr_main_financial_statements(财务报表主表)】的数据库操作Service实现
  18. * @createDate 2024-10-17 10:37:12
  19. */
  20. @Service
  21. @Slf4j
  22. public class XcrMainFinancialStatementsServiceImpl extends ServiceImpl<XcrMainFinancialStatementsMapper, XcrMainFinancialStatements>
  23. implements XcrMainFinancialStatementsService{
  24. @Autowired
  25. private XhRequestUtil xhRequestUtil;
  26. @Autowired
  27. private RedisService redisService;
  28. @Override
  29. @Transactional(rollbackFor = Exception.class)
  30. public void saveDataByUniCode(String address) {
  31. //模拟从数据库中取数据大约为3000-4000条
  32. List<String> creditCodes = (List<String>) redisService.getList("creditCodes").get(0);
  33. Vector<XcrMainFinancialStatements> toDatabaseList = new Vector<>();
  34. creditCodes.parallelStream().forEach(creditCode -> {
  35. List<XcrMainFinancialStatements> list = xhRequestUtil.httpRequestByUniCode(creditCode, address,
  36. XcrMainFinancialStatementsResponse.class,
  37. XcrMainFinancialStatements.class,
  38. "NSRSBH"
  39. );
  40. if(list != null){
  41. toDatabaseList.addAll(list);
  42. }
  43. });
  44. this.remove(null);
  45. this.saveBatch(toDatabaseList);
  46. log.info("财务报表主表信息同步完成");
  47. }
  48. }