XcrOtherInfo38ServiceImpl.java 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package com.zksy.data.service.impl;
  2. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  3. import com.zksy.common.exception.DbException;
  4. import com.zksy.data.annotation.XhDataLogRecord;
  5. import com.zksy.data.domain.po.XcrOtherInfo38;
  6. import com.zksy.data.domain.response.XcrOtherInfo38Response;
  7. import com.zksy.data.mapper.XcrOtherInfo38Mapper;
  8. import com.zksy.data.service.XcrOtherInfo38Service;
  9. import com.zksy.data.utils.RedisService;
  10. import com.zksy.data.utils.XhRequestUtil;
  11. import lombok.extern.slf4j.Slf4j;
  12. import org.springframework.beans.factory.annotation.Autowired;
  13. import org.springframework.stereotype.Service;
  14. import org.springframework.transaction.support.TransactionTemplate;
  15. import java.util.HashMap;
  16. import java.util.List;
  17. import java.util.Vector;
  18. /**
  19. * @author Administrator
  20. * @description 针对表【xcr_other_info_38(科技研发清单表)】的数据库操作Service实现
  21. * @createDate 2024-10-15 11:09:09
  22. */
  23. @Service
  24. @Slf4j
  25. public class XcrOtherInfo38ServiceImpl extends ServiceImpl<XcrOtherInfo38Mapper, XcrOtherInfo38>
  26. implements XcrOtherInfo38Service{
  27. @Autowired
  28. private XhRequestUtil xhRequestUtil;
  29. @Autowired
  30. private RedisService redisService;
  31. @Autowired
  32. private TransactionTemplate transactionTemplate;
  33. @Override
  34. @XhDataLogRecord("同步科技研发清单表")
  35. public void saveDataByUniCode(String address) {
  36. //模拟从数据库中取数据大约为3000-4000条
  37. List<String> creditCodes = (List<String>) redisService.getList("creditCodes").get(0);
  38. Vector<XcrOtherInfo38> toDatabaseList = new Vector<>();
  39. List<String> inventoryList = List.of("38");
  40. inventoryList.parallelStream().forEach(inventory -> {
  41. creditCodes.parallelStream().forEach(creditCode -> {
  42. HashMap<String, String> requestbodyMap = new HashMap<>();
  43. requestbodyMap.put("entityCode", creditCode);
  44. requestbodyMap.put("size", String.valueOf(10));
  45. requestbodyMap.put("page", String.valueOf(1));
  46. requestbodyMap.put("inventoryId", inventory);
  47. try {
  48. List<XcrOtherInfo38> list = xhRequestUtil.requestXinyonghuanhuai2(requestbodyMap,address,
  49. XcrOtherInfo38Response.class,
  50. XcrOtherInfo38.class);
  51. if(list != null){
  52. toDatabaseList.addAll(list);
  53. }
  54. } catch (Exception e) {
  55. List<XcrOtherInfo38> list = xhRequestUtil.requestXinyonghuanhuai2(requestbodyMap,address,
  56. XcrOtherInfo38Response.class,
  57. XcrOtherInfo38.class);
  58. if(list != null){
  59. toDatabaseList.addAll(list);
  60. }
  61. }
  62. });
  63. log.info("inventorywe为:{}完成",inventory);
  64. });
  65. transactionTemplate.execute((s)->{
  66. try {
  67. this.remove(null);
  68. this.saveBatch(toDatabaseList);
  69. } catch (Exception e) {
  70. s.setRollbackOnly();
  71. throw new DbException(e);
  72. }
  73. return null;
  74. });
  75. log.info("科技研发清单表同步完成");
  76. }
  77. }