DeletionServiceImpl.java 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825
  1. package com.simuwang.manage.service.impl;
  2. import cn.hutool.core.date.DateUtil;
  3. import com.simuwang.base.common.enums.DeletionType;
  4. import com.simuwang.base.common.enums.DistributeType;
  5. import com.simuwang.base.common.enums.Frequency;
  6. import com.simuwang.base.common.support.MybatisPage;
  7. import com.simuwang.base.common.util.DateUtils;
  8. import com.simuwang.base.common.util.StringUtil;
  9. import com.simuwang.base.mapper.daq.*;
  10. import com.simuwang.base.pojo.dos.*;
  11. import com.simuwang.base.pojo.dto.DeletionDownParam;
  12. import com.simuwang.base.pojo.dto.EmailInfoDTO;
  13. import com.simuwang.base.pojo.dto.ExcelDeletionInfoDTO;
  14. import com.simuwang.base.pojo.dto.query.DeletionPageQuery;
  15. import com.simuwang.base.pojo.dto.query.FundDeletionPageQuery;
  16. import com.simuwang.base.pojo.vo.*;
  17. import com.simuwang.manage.service.DeletionService;
  18. import com.simuwang.shiro.utils.UserUtils;
  19. import org.slf4j.Logger;
  20. import org.slf4j.LoggerFactory;
  21. import org.springframework.beans.factory.annotation.Autowired;
  22. import org.springframework.stereotype.Service;
  23. import java.math.BigDecimal;
  24. import java.util.*;
  25. import java.util.stream.Collectors;
  26. /**
  27. * FileName: DeletionServiceImpl
  28. * Author: chenjianhua
  29. * Date: 2024/9/17 18:54
  30. * Description: ${DESCRIPTION}
  31. */
  32. @Service
  33. public class DeletionServiceImpl implements DeletionService {
  34. private static final Logger log = LoggerFactory.getLogger(DeletionServiceImpl.class);
  35. @Autowired
  36. private DeletionInfoMapper deletionInfoMapper;
  37. @Autowired
  38. private FundInfoMapper fundInfoMapper;
  39. @Autowired
  40. private FundPositionDetailMapper fundPositionDetailMapper;
  41. @Autowired
  42. private AssetMapper assetMapper;
  43. @Autowired
  44. private FundReportFrequencyMapper fundReportFrequencyMapper;
  45. @Autowired
  46. private TradeDateMapper tradeDateMapper;
  47. @Autowired
  48. private DistributionMapper distributionMapper;
  49. @Autowired
  50. private ChannelEmailMapper channelEmailMapper;
  51. @Autowired
  52. private NavMapper navMapper;
  53. @Override
  54. public MybatisPage<DeletionInfoVO> searchDeletionList(DeletionPageQuery deletionPageQuery) {
  55. List<DeletionInfoDO> deletionInfoDOList = deletionInfoMapper.searchDeletionList(deletionPageQuery);
  56. long total = deletionInfoMapper.countDeletion(deletionPageQuery);
  57. List<DeletionInfoVO> dataList = deletionInfoDOList.stream().map(DeletionInfoDO::toVO).collect(Collectors.toList());
  58. return MybatisPage.of(total,dataList);
  59. }
  60. @Override
  61. public MybatisPage<FundDeletionInfoVO> searchFundDeletionList(FundDeletionPageQuery fundDeletionPageQuery) {
  62. List<FundDeletionInfoDO> deletionInfoDOList = deletionInfoMapper.searchFundDeletionList(fundDeletionPageQuery);
  63. long total = deletionInfoMapper.countFundDeletionList(fundDeletionPageQuery);
  64. List<FundDeletionInfoVO> dataList = deletionInfoDOList.stream().map(FundDeletionInfoDO::toVO).collect(Collectors.toList());
  65. return MybatisPage.of(total,dataList);
  66. }
  67. @Override
  68. public void saveFundDeletionList(List<FundDeletionInfoVO> fundDeletionInfoVOList) {
  69. List<FundDeletionInfoDO> fundDeletionInfoDOList = new ArrayList<>();
  70. for(FundDeletionInfoVO vo : fundDeletionInfoVOList){
  71. FundDeletionInfoDO fundDeletionInfoDO = new FundDeletionInfoDO();
  72. fundDeletionInfoDO.setId(vo.getId());
  73. fundDeletionInfoDO.setChannelId(vo.getChannelId());
  74. fundDeletionInfoDO.setDeletionType(vo.getDeletionType());
  75. fundDeletionInfoDO.setFundId(vo.getFundId());
  76. fundDeletionInfoDO.setDeletionDate(vo.getDeletionDate());
  77. fundDeletionInfoDO.setRemark(vo.getRemark());
  78. fundDeletionInfoDO.setIsvalid(1);
  79. fundDeletionInfoDO.setUpdateTime(DateUtils.getNowDate());
  80. fundDeletionInfoDO.setUpdaterId(UserUtils.getLoginUser().getUserId());
  81. fundDeletionInfoDOList.add(fundDeletionInfoDO);
  82. }
  83. deletionInfoMapper.batchUpdate(fundDeletionInfoDOList);
  84. }
  85. @Override
  86. public void saveBatchDeletionRemark(FundDeletionRemarkVO fundDeletionRemarkVO) {
  87. String remark = fundDeletionRemarkVO.getRemark();
  88. Integer userId = UserUtils.getLoginUser().getUserId();
  89. for(FundDeletionTypeVO remarkVO : fundDeletionRemarkVO.getFundDeletionTypeList()){
  90. deletionInfoMapper.updateRemark(remarkVO.getChannelId(),remarkVO.getFundId(),remarkVO.getDeletionType(),remarkVO.getDeletionDate(),remark,userId);
  91. }
  92. }
  93. @Override
  94. public List<ExcelDeletionInfoDTO> selectFundDeletionInfoVOList(FundDeletionListVO fundDeletionListVO) {
  95. List<ExcelDeletionInfoDTO> result = new ArrayList<>();
  96. List<DeletionDownParam> deletionDownParamList = fundDeletionListVO.getDeletionDownParamList();
  97. for(DeletionDownParam deletionDownParam : deletionDownParamList){
  98. List<FundDeletionInfoDO> deletionInfoDOList = deletionInfoMapper.selectFundDeletionInfoVOList(deletionDownParam.getFundId(),deletionDownParam.getDeletionType());
  99. for(FundDeletionInfoDO infoDO : deletionInfoDOList){
  100. ExcelDeletionInfoDTO dto = new ExcelDeletionInfoDTO();
  101. dto.setFundName(fundInfoMapper.getFundNameByFundId(infoDO.getFundId()));
  102. dto.setCompanyName(fundInfoMapper.getCompanyNameByFundId(infoDO.getFundId()));
  103. dto.setDeletionType(DeletionType.getDeletionTypeByCode(infoDO.getDeletionType()).getInfo());
  104. dto.setDeletionDate(infoDO.getDeletionDate());
  105. dto.setRemark(infoDO.getRemark());
  106. dto.setFundId(infoDO.getFundId());
  107. result.add(dto);
  108. }
  109. }
  110. return result;
  111. }
  112. @Override
  113. public void computeDeletion(List<MailboxInfoDO> mailboxInfoDOList) {
  114. Map<Integer,List<String>> channelEmailMap = new HashMap<>();
  115. //按渠道分组
  116. for (MailboxInfoDO mailboxInfoDO : mailboxInfoDOList) {
  117. try{
  118. String email = mailboxInfoDO.getEmail();
  119. Integer channelId = channelEmailMapper.selectChannelIdByEmail(email);
  120. if(channelId == null){
  121. continue;
  122. }
  123. if(!channelEmailMap.containsKey(channelId)){
  124. List<String> channelEmailList = new ArrayList<>();
  125. channelEmailList.add(email);
  126. channelEmailMap.put(channelId,channelEmailList);
  127. }else{
  128. List<String> channelEmailList = channelEmailMap.get(channelId);
  129. channelEmailList.add(email);
  130. channelEmailMap.put(channelId,channelEmailList);
  131. }
  132. }catch (Exception e){
  133. log.error(e.getMessage(),e);
  134. }
  135. }
  136. for (Integer channelId : channelEmailMap.keySet()) {
  137. List<NavDO> navDOList = navMapper.selectNavByChannelId(channelId);
  138. Map<String,List<NavDO>> fundIdNavMap = navDOList.stream().collect(Collectors.groupingBy(NavDO::getFundId));
  139. for (String fundId : fundIdNavMap.keySet()) {
  140. String liquidateDate = fundInfoMapper.getLiquidateDateByFundId(fundId);
  141. if(StringUtil.isNotEmpty(liquidateDate)){
  142. return;
  143. }
  144. String inceptionDate = fundInfoMapper.getInceptionDateByFundId(fundId);
  145. if(StringUtil.isEmpty(inceptionDate)){
  146. return;
  147. }
  148. String today = DateUtils.getAroundToday(0);
  149. //获取基金对应的净值报送频率
  150. FundReportFrequencyDO fundReportFrequencyDO = fundReportFrequencyMapper.getFrequencyByFundId(fundId);
  151. if(StringUtil.isNull(fundReportFrequencyDO)){
  152. return;
  153. }
  154. List<NavDO> fundNavDOList = fundIdNavMap.get(fundId);
  155. //查询成立日到今天为止的交易日集合
  156. List<TradeDateDO> tradeDateDOList = tradeDateMapper.selectTradeDate(inceptionDate,today);
  157. navDeletion(channelId,fundId,fundNavDOList,tradeDateDOList,fundReportFrequencyDO);
  158. List<AssetDO> assetDOList = assetMapper.selectAssetByFundId(fundId,channelId);
  159. List<FundPositionDetailDO> fundPositionDetailDOList = fundPositionDetailMapper.fundPositionDetailByFundId(fundId,channelId);
  160. assetDeletion(channelId,fundId,assetDOList,tradeDateDOList,fundReportFrequencyDO);
  161. distributionDeletion(channelId,fundId,navDOList);
  162. valuationDeletion(channelId,fundId,fundPositionDetailDOList,tradeDateDOList,fundReportFrequencyDO);
  163. }
  164. }
  165. }
  166. @Override
  167. public int countFundDeletion(String fundId) {
  168. return deletionInfoMapper.countFundDeletion(fundId);
  169. }
  170. @Override
  171. public List<EmailDeletionInfoDO> selectDeletionInfoByFundId(String fundId,String updateTime) {
  172. //只查询每日新增的缺失数据
  173. return deletionInfoMapper.selectDeletionDetailByFundId(fundId,updateTime);
  174. }
  175. private void distributionDeletion(Integer channelId,String fundId, List<NavDO> navDOList) {
  176. if(navDOList.size() < 1){
  177. return;
  178. }
  179. //将现有数据无效掉
  180. deletionInfoMapper.deleteDeletion(channelId,fundId,DeletionType.DISTRIBUTION_DELETION.getCode());
  181. //查询是否存在拆分
  182. List<DistributionDO> distributionDOS = distributionMapper.getDistributionByFundId(channelId,fundId, DistributeType.DIVIDENDS_SPLIT.getCode());
  183. if(distributionDOS.size() > 0){
  184. //存在拆分,不做分红缺失计算,同时把以往的数据添加备注
  185. deletionInfoMapper.updateRemark(channelId,fundId,DeletionType.DISTRIBUTION_DELETION.getCode(),null,DeletionType.EXIST_SPLIT.getInfo(),null);
  186. return;
  187. }
  188. BigDecimal threshold = new BigDecimal(0.0035);
  189. BigDecimal preDifference = new BigDecimal(0);
  190. List<String> tradeDateList = new ArrayList<>();
  191. for(int navIdx=0;navIdx < navDOList.size() ;navIdx++){
  192. NavDO navDO = navDOList.get(navIdx);
  193. //获取当前净值日期下的分红总和
  194. BigDecimal sumDistribute = distributionMapper.getSumDistributeByFundId(navDO.getFundId(),DateUtils.format(navDO.getPriceDate(),DateUtils.YYYY_MM_DD));
  195. BigDecimal nav = navDO.getNav();
  196. BigDecimal cumulativeNavWithdrawal = navDO.getCumulativeNavWithdrawal();
  197. if(sumDistribute == null){
  198. sumDistribute = new BigDecimal(0);
  199. }
  200. //判断当前的差值是否符合要求
  201. BigDecimal difference = cumulativeNavWithdrawal.subtract(nav.add(sumDistribute));
  202. if(difference.compareTo(threshold) > 0){
  203. //存在缺失
  204. String tradeDate = null;
  205. if(navIdx == 0 || navDOList.size() ==1){
  206. //有且仅有一条数据
  207. tradeDate = DateUtils.format(navDO.getPriceDate(),DateUtils.YYYY_MM_DD)+"~"+DateUtils.format(navDO.getPriceDate(),DateUtils.YYYY_MM_DD);
  208. }else{
  209. //判断前一条的差值与当前是否一致,一致就不处理
  210. if(difference.compareTo(preDifference) == 0){
  211. continue;
  212. }
  213. tradeDate = DateUtils.format(navDOList.get(navIdx-1).getPriceDate(),DateUtils.YYYY_MM_DD)+"~"+DateUtils.format(navDO.getPriceDate(),DateUtils.YYYY_MM_DD);
  214. }
  215. tradeDateList.add(tradeDate);
  216. }
  217. preDifference = difference;
  218. }
  219. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.DISTRIBUTION_DELETION.getCode());
  220. }
  221. private void assetDeletion(Integer channelId,String fundId, List<AssetDO> assetDOList, List<TradeDateDO> tradeDateDOList, FundReportFrequencyDO fundReportFrequencyDO) {
  222. //将现有数据无效掉
  223. deletionInfoMapper.deleteDeletion(channelId,fundId,DeletionType.ASSET_DELETION.getCode());
  224. List<String> tradeDateList = new ArrayList<>();
  225. if(Frequency.DAY == Frequency.getFrequencyByCode(fundReportFrequencyDO.getAssetFrequency())){
  226. Map<String,List<AssetDO>> navListMap = assetDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getPriceDate(),DateUtils.YYYY_MM_DD)));
  227. Map<String,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getTradeDate(),DateUtils.YYYY_MM_DD)));
  228. List<String> updateTradeDateList = new ArrayList<>();
  229. for(String tradeDate : tradeListMap.keySet()){
  230. if(navListMap.containsKey(tradeDate)){
  231. updateTradeDateList.add(tradeDate);
  232. continue;
  233. }
  234. if(tradeDateDOList.size() <= 3){
  235. continue;
  236. }
  237. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  238. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  239. continue;
  240. }
  241. tradeDateList.add(tradeDate);
  242. }
  243. if(updateTradeDateList.size() > 0){
  244. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  245. for(String tradeDate : updateTradeDateList){
  246. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  247. deletionInfoDO.setFundId(fundId);
  248. deletionInfoDO.setChannelId(channelId);
  249. deletionInfoDO.setDeletionType(DeletionType.ASSET_DELETION.getCode());
  250. deletionInfoDO.setDeletionDate(tradeDate);
  251. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  252. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  253. }
  254. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  255. }
  256. //写入缺失信息表
  257. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.ASSET_DELETION.getCode());
  258. }
  259. if(Frequency.WEEK == Frequency.getFrequencyByCode(fundReportFrequencyDO.getAssetFrequency())){
  260. Map<String,List<AssetDO>> navListMap = assetDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getPriceDate(),DateUtils.YYYY_MM_DD)));
  261. TreeMap<Integer,List<AssetDO>> weekNavListMap = new TreeMap<>();
  262. //按周数整合
  263. for(String priceDate : navListMap.keySet()){
  264. Integer weekOfYear = Integer.parseInt(priceDate.substring(0,4)+DateUtil.weekOfYear(DateUtils.parse(priceDate,DateUtils.YYYY_MM_DD)));
  265. if(weekNavListMap.containsKey(weekOfYear)){
  266. List<AssetDO> assetDOS = weekNavListMap.get(weekOfYear);
  267. assetDOS.addAll(navListMap.get(priceDate));
  268. weekNavListMap.put(weekOfYear,assetDOS);
  269. }else{
  270. List<AssetDO> navDOS = new ArrayList<>();
  271. navDOS.addAll(navListMap.get(priceDate));
  272. weekNavListMap.put(weekOfYear,navDOS);
  273. }
  274. }
  275. Map<Integer,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> e.getYearWeek()));
  276. for(Integer weekOfYear : tradeListMap.keySet()){
  277. List<AssetDO> assetDOS = weekNavListMap.get(weekOfYear);
  278. if(weekNavListMap.containsKey(weekOfYear)){
  279. List<String> updateTradeDateList = new ArrayList<>();
  280. for(TradeDateDO tradeDateDO : tradeListMap.get(weekOfYear)){
  281. String tradeDate = DateUtils.format(tradeDateDO.getTradeDate(),DateUtils.YYYY_MM_DD);
  282. updateTradeDateList.add(tradeDate);
  283. }
  284. if(updateTradeDateList.size() > 0){
  285. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  286. for(String tradeDate : updateTradeDateList){
  287. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  288. deletionInfoDO.setFundId(fundId);
  289. deletionInfoDO.setDeletionType(DeletionType.ASSET_DELETION.getCode());
  290. deletionInfoDO.setDeletionDate(tradeDate);
  291. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  292. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  293. }
  294. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  295. }
  296. continue;
  297. }else{
  298. if(StringUtil.isNotEmpty(assetDOS)){
  299. List<String> deleteTradeDateList = new ArrayList<>();
  300. for(int idx=0;idx < assetDOS.size()-1 ; idx++){
  301. AssetDO assetDO = assetDOS.get(idx);
  302. String tradeDate = DateUtils.format(assetDO.getPriceDate(),DateUtils.YYYY_MM_DD);
  303. deleteTradeDateList.add(tradeDate);
  304. }
  305. deletionInfoMapper.deleteDeletionRemark(fundId,DeletionType.ASSET_DELETION.getCode(),deleteTradeDateList);
  306. }
  307. }
  308. //不包含的话,默认取每周的最后一个交易日作为周净值日期
  309. List<TradeDateDO> tradeDateDOS = tradeListMap.get(weekOfYear);
  310. String tradeDate = null;
  311. if(tradeDateDOS.size() > 0){
  312. tradeDate = DateUtils.format(tradeDateDOS.get(tradeDateDOS.size()-1).getTradeDate(),DateUtils.YYYY_MM_DD);
  313. }
  314. //判断当前缺失交易日是否是近三个交易日
  315. if(tradeDateDOList.size() <= 3){
  316. continue;
  317. }
  318. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  319. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  320. continue;
  321. }
  322. tradeDateList.add(tradeDate);
  323. }
  324. //写入缺失信息表
  325. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.ASSET_DELETION.getCode());
  326. }
  327. if(Frequency.MONTH == Frequency.getFrequencyByCode(fundReportFrequencyDO.getAssetFrequency())){
  328. Map<String,List<AssetDO>> navListMap = assetDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getPriceDate(),DateUtils.YYYY_MM_DD)));
  329. TreeMap<String,List<AssetDO>> monthNavListMap = new TreeMap<>();
  330. //按周数整合
  331. for(String priceDate : navListMap.keySet()){
  332. String yearMonth = priceDate.substring(0,7);
  333. if(monthNavListMap.containsKey(yearMonth)){
  334. List<AssetDO> navDOS = monthNavListMap.get(yearMonth);
  335. navDOS.addAll(navListMap.get(priceDate));
  336. monthNavListMap.put(yearMonth,navDOS);
  337. }else{
  338. List<AssetDO> navDOS = new ArrayList<>();
  339. navDOS.addAll(navListMap.get(priceDate));
  340. monthNavListMap.put(yearMonth,navDOS);
  341. }
  342. }
  343. Map<String,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> e.getYearmonth()));
  344. for(String yearMonth : tradeListMap.keySet()){
  345. //本月的数据不考虑
  346. String thisMonth = DateUtils.format(new Date(),DateUtils.YYYY_MM);
  347. if(yearMonth.equals(thisMonth)){
  348. continue;
  349. }
  350. List<AssetDO> assetDOS = monthNavListMap.get(yearMonth);
  351. if(monthNavListMap.containsKey(yearMonth)){
  352. List<String> updateTradeDateList = new ArrayList<>();
  353. for(TradeDateDO tradeDateDO : tradeListMap.get(yearMonth)){
  354. String tradeDate = DateUtils.format(tradeDateDO.getTradeDate(),DateUtils.YYYY_MM_DD);
  355. updateTradeDateList.add(tradeDate);
  356. }
  357. if(updateTradeDateList.size() > 0){
  358. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  359. for(String tradeDate : updateTradeDateList){
  360. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  361. deletionInfoDO.setFundId(fundId);
  362. deletionInfoDO.setDeletionType(DeletionType.ASSET_DELETION.getCode());
  363. deletionInfoDO.setDeletionDate(tradeDate);
  364. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  365. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  366. }
  367. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  368. }
  369. continue;
  370. }else{
  371. if(StringUtil.isNotEmpty(assetDOS)){
  372. List<String> deleteTradeDateList = new ArrayList<>();
  373. for(int idx=0;idx < assetDOS.size()-1 ; idx++){
  374. AssetDO assetDO = assetDOS.get(idx);
  375. String tradeDate = DateUtils.format(assetDO.getPriceDate(),DateUtils.YYYY_MM_DD);
  376. deleteTradeDateList.add(tradeDate);
  377. }
  378. deletionInfoMapper.deleteDeletionRemark(fundId,DeletionType.ASSET_DELETION.getCode(),deleteTradeDateList);
  379. }
  380. }
  381. //不包含的话,默认取每月的最后一个交易日作为周净值日期
  382. List<TradeDateDO> tradeDateDOS = tradeListMap.get(yearMonth);
  383. String tradeDate = null;
  384. if(tradeDateDOS.size() > 0){
  385. tradeDate = DateUtils.format(tradeDateDOS.get(tradeDateDOS.size()-1).getTradeDate(),DateUtils.YYYY_MM_DD);
  386. }
  387. if(tradeDateDOList.size() <= 3){
  388. continue;
  389. }
  390. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  391. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  392. continue;
  393. }
  394. tradeDateList.add(tradeDate);
  395. }
  396. //写入缺失信息表
  397. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.ASSET_DELETION.getCode());
  398. }
  399. }
  400. private void navDeletion(Integer channelId,String fundId,List<NavDO> navDOList, List<TradeDateDO> tradeDateDOList,FundReportFrequencyDO fundReportFrequencyDO) {
  401. //将现有数据无效掉
  402. deletionInfoMapper.deleteDeletion(channelId,fundId,DeletionType.NAV_DELETION.getCode());
  403. List<String> tradeDateList = new ArrayList<>();
  404. //只处理日月季频率
  405. if(Frequency.DAY == Frequency.getFrequencyByCode(fundReportFrequencyDO.getNavFrequency())){
  406. Map<String,List<NavDO>> navListMap = navDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getPriceDate(),DateUtils.YYYY_MM_DD)));
  407. Map<String,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getTradeDate(),DateUtils.YYYY_MM_DD)));
  408. List<String> updateTradeDateList = new ArrayList<>();
  409. for(String tradeDate : tradeListMap.keySet()){
  410. if(navListMap.containsKey(tradeDate)){
  411. updateTradeDateList.add(tradeDate);
  412. continue;
  413. }
  414. if(tradeDateDOList.size() <= 3){
  415. continue;
  416. }
  417. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  418. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  419. continue;
  420. }
  421. tradeDateList.add(tradeDate);
  422. }
  423. if(updateTradeDateList.size() > 0){
  424. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  425. for(String tradeDate : updateTradeDateList){
  426. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  427. deletionInfoDO.setFundId(fundId);
  428. deletionInfoDO.setChannelId(channelId);
  429. deletionInfoDO.setDeletionType(DeletionType.NAV_DELETION.getCode());
  430. deletionInfoDO.setDeletionDate(tradeDate);
  431. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  432. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  433. }
  434. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  435. }
  436. //写入缺失信息表
  437. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.NAV_DELETION.getCode());
  438. }
  439. if(Frequency.WEEK == Frequency.getFrequencyByCode(fundReportFrequencyDO.getNavFrequency())){
  440. Map<String,List<NavDO>> navListMap = navDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getPriceDate(),DateUtils.YYYY_MM_DD)));
  441. TreeMap<Integer,List<NavDO>> weekNavListMap = new TreeMap<>();
  442. //按周数整合
  443. for(String priceDate : navListMap.keySet()){
  444. Integer weekOfYear = Integer.parseInt(priceDate.substring(0,4)+DateUtil.weekOfYear(DateUtils.parse(priceDate,DateUtils.YYYY_MM_DD)));;
  445. if(weekNavListMap.containsKey(weekOfYear)){
  446. List<NavDO> navDOS = weekNavListMap.get(weekOfYear);
  447. navDOS.addAll(navListMap.get(priceDate));
  448. weekNavListMap.put(weekOfYear,navDOS);
  449. }else{
  450. List<NavDO> navDOS = new ArrayList<>();
  451. navDOS.addAll(navListMap.get(priceDate));
  452. weekNavListMap.put(weekOfYear,navDOS);
  453. }
  454. }
  455. Map<Integer,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> e.getYearWeek()));
  456. for(Integer weekOfYear : tradeListMap.keySet()){
  457. List<NavDO> navDOS = weekNavListMap.get(weekOfYear);
  458. if(weekNavListMap.containsKey(weekOfYear)){
  459. List<String> deleteTradeDateList = new ArrayList<>();
  460. for(TradeDateDO tradeDateDO : tradeListMap.get(weekOfYear)){
  461. String tradeDate = DateUtils.format(tradeDateDO.getTradeDate(),DateUtils.YYYY_MM_DD);
  462. deleteTradeDateList.add(tradeDate);
  463. }
  464. if(deleteTradeDateList.size() > 0){
  465. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  466. for(String tradeDate : deleteTradeDateList){
  467. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  468. deletionInfoDO.setFundId(fundId);
  469. deletionInfoDO.setDeletionType(DeletionType.NAV_DELETION.getCode());
  470. deletionInfoDO.setDeletionDate(tradeDate);
  471. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  472. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  473. }
  474. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  475. }
  476. continue;
  477. }else{
  478. //防止频率变更导致数据异常,需要把当前日期下所在的频率全部无效掉
  479. if(StringUtil.isNotEmpty(navDOS)){
  480. List<String> deleteTradeDateList = new ArrayList<>();
  481. for(int idx=0;idx < navDOS.size()-1 ; idx++){
  482. NavDO navDO = navDOS.get(idx);
  483. String tradeDate = DateUtils.format(navDO.getPriceDate(),DateUtils.YYYY_MM_DD);
  484. deleteTradeDateList.add(tradeDate);
  485. }
  486. deletionInfoMapper.deleteDeletionRemark(fundId,DeletionType.NAV_DELETION.getCode(),deleteTradeDateList);
  487. }
  488. }
  489. //不包含的话,默认取每周的最后一个交易日作为周净值日期
  490. List<TradeDateDO> tradeDateDOS = tradeListMap.get(weekOfYear);
  491. String tradeDate = null;
  492. if(tradeDateDOS.size() > 0){
  493. tradeDate = DateUtils.format(tradeDateDOS.get(tradeDateDOS.size()-1).getTradeDate(),DateUtils.YYYY_MM_DD);
  494. }
  495. if(tradeDateDOList.size() <= 3){
  496. continue;
  497. }
  498. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  499. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  500. continue;
  501. }
  502. tradeDateList.add(tradeDate);
  503. }
  504. //写入缺失信息表
  505. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.NAV_DELETION.getCode());
  506. }
  507. if(Frequency.MONTH == Frequency.getFrequencyByCode(fundReportFrequencyDO.getNavFrequency())){
  508. Map<String,List<NavDO>> navListMap = navDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getPriceDate(),DateUtils.YYYY_MM_DD)));
  509. TreeMap<String,List<NavDO>> monthNavListMap = new TreeMap<>();
  510. //按周数整合
  511. for(String priceDate : navListMap.keySet()){
  512. String yearMonth = priceDate.substring(0,7);
  513. if(monthNavListMap.containsKey(yearMonth)){
  514. List<NavDO> navDOS = monthNavListMap.get(yearMonth);
  515. navDOS.addAll(navListMap.get(priceDate));
  516. monthNavListMap.put(yearMonth,navDOS);
  517. }else{
  518. List<NavDO> navDOS = new ArrayList<>();
  519. navDOS.addAll(navListMap.get(priceDate));
  520. monthNavListMap.put(yearMonth,navDOS);
  521. }
  522. }
  523. Map<String,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> e.getYearmonth()));
  524. for(String yearMonth : tradeListMap.keySet()){
  525. //本月的数据不考虑
  526. String thisMonth = DateUtils.format(new Date(),DateUtils.YYYY_MM);
  527. if(yearMonth.equals(thisMonth)){
  528. continue;
  529. }
  530. List<NavDO> navDOS = monthNavListMap.get(yearMonth);
  531. if(monthNavListMap.containsKey(yearMonth)){
  532. List<String> batchUpdateTradeList = new ArrayList<>();
  533. for(TradeDateDO tradeDateDO : tradeListMap.get(yearMonth)){
  534. String tradeDate = DateUtils.format(tradeDateDO.getTradeDate(),DateUtils.YYYY_MM_DD);
  535. batchUpdateTradeList.add(tradeDate);
  536. }
  537. if(batchUpdateTradeList.size() > 0){
  538. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  539. for(String tradeDate : batchUpdateTradeList){
  540. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  541. deletionInfoDO.setFundId(fundId);
  542. deletionInfoDO.setDeletionType(DeletionType.NAV_DELETION.getCode());
  543. deletionInfoDO.setDeletionDate(tradeDate);
  544. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  545. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  546. }
  547. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  548. }
  549. continue;
  550. }else{
  551. //防止频率变更导致数据异常,需要把当前日期下所在的频率全部无效掉
  552. if(StringUtil.isNotEmpty(navDOS)){
  553. List<String> deleteTradeDateList = new ArrayList<>();
  554. for(NavDO navDO : navDOS){
  555. String tradeDate = DateUtils.format(navDO.getPriceDate(),DateUtils.YYYY_MM_DD);
  556. deleteTradeDateList.add(tradeDate);
  557. }
  558. deletionInfoMapper.deleteDeletionRemark(fundId,DeletionType.NAV_DELETION.getCode(),deleteTradeDateList);
  559. }
  560. }
  561. //不包含的话,默认取每月的最后一个交易日作为周净值日期
  562. List<TradeDateDO> tradeDateDOS = tradeListMap.get(yearMonth);
  563. String tradeDate = null;
  564. if(tradeDateDOS.size() > 0){
  565. tradeDate = DateUtils.format(tradeDateDOS.get(tradeDateDOS.size()-1).getTradeDate(),DateUtils.YYYY_MM_DD);
  566. }
  567. if(tradeDateDOList.size() <= 3){
  568. continue;
  569. }
  570. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  571. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  572. continue;
  573. }
  574. tradeDateList.add(tradeDate);
  575. }
  576. //写入缺失信息表
  577. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.NAV_DELETION.getCode());
  578. }
  579. }
  580. private void valuationDeletion(Integer channelId,String fundId,List<FundPositionDetailDO> fundPositionDetailDOList, List<TradeDateDO> tradeDateDOList,FundReportFrequencyDO fundReportFrequencyDO) {
  581. //将现有数据无效掉
  582. deletionInfoMapper.deleteDeletion(channelId,fundId,DeletionType.VALUATION_DELETION.getCode());
  583. List<String> tradeDateList = new ArrayList<>();
  584. //只处理日月季频率
  585. if(Frequency.DAY == Frequency.getFrequencyByCode(fundReportFrequencyDO.getValuationFrequency())){
  586. Map<String,List<FundPositionDetailDO>> valuationListMap = fundPositionDetailDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getValuationDate(),DateUtils.YYYY_MM_DD)));
  587. Map<String,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getTradeDate(),DateUtils.YYYY_MM_DD)));
  588. List<String> batchUpdateTrade = new ArrayList<>();
  589. for(String tradeDate : tradeListMap.keySet()){
  590. if(valuationListMap.containsKey(tradeDate)){
  591. batchUpdateTrade.add(tradeDate);
  592. continue;
  593. }
  594. if(tradeDateDOList.size() <= 3){
  595. continue;
  596. }
  597. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  598. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  599. continue;
  600. }
  601. tradeDateList.add(tradeDate);
  602. }
  603. if(batchUpdateTrade.size() > 0){
  604. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  605. for(String tradeDate : batchUpdateTrade){
  606. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  607. deletionInfoDO.setFundId(fundId);
  608. deletionInfoDO.setDeletionType(DeletionType.VALUATION_DELETION.getCode());
  609. deletionInfoDO.setDeletionDate(tradeDate);
  610. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  611. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  612. }
  613. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  614. }
  615. //写入缺失信息表
  616. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.VALUATION_DELETION.getCode());
  617. }
  618. if(Frequency.WEEK == Frequency.getFrequencyByCode(fundReportFrequencyDO.getValuationFrequency())){
  619. Map<String,List<FundPositionDetailDO>> valuationListMap = fundPositionDetailDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getValuationDate(),DateUtils.YYYY_MM_DD)));
  620. TreeMap<Integer,List<FundPositionDetailDO>> weekNavListMap = new TreeMap<>();
  621. //按周数整合
  622. for(String priceDate : valuationListMap.keySet()){
  623. Integer weekOfYear = Integer.parseInt(priceDate.substring(0,4)+DateUtil.weekOfYear(DateUtils.parse(priceDate,DateUtils.YYYY_MM_DD)));;
  624. if(weekNavListMap.containsKey(weekOfYear)){
  625. List<FundPositionDetailDO> valuationDOS = weekNavListMap.get(weekOfYear);
  626. valuationDOS.addAll(valuationListMap.get(priceDate));
  627. weekNavListMap.put(weekOfYear,valuationDOS);
  628. }else{
  629. List<FundPositionDetailDO> valuationDOS = new ArrayList<>();
  630. valuationDOS.addAll(valuationListMap.get(priceDate));
  631. weekNavListMap.put(weekOfYear,valuationDOS);
  632. }
  633. }
  634. Map<Integer,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> e.getYearWeek()));
  635. for(Integer weekOfYear : tradeListMap.keySet()){
  636. List<FundPositionDetailDO> valuationDOS = weekNavListMap.get(weekOfYear);
  637. if(weekNavListMap.containsKey(weekOfYear)){
  638. List<String> batchUpdateTradeList = new ArrayList<>();
  639. for(TradeDateDO tradeDateDO : tradeListMap.get(weekOfYear)){
  640. String tradeDate = DateUtils.format(tradeDateDO.getTradeDate(),DateUtils.YYYY_MM_DD);
  641. batchUpdateTradeList.add(tradeDate);
  642. }
  643. if(batchUpdateTradeList.size() > 0){
  644. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  645. for(String tradeDate : batchUpdateTradeList){
  646. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  647. deletionInfoDO.setFundId(fundId);
  648. deletionInfoDO.setDeletionType(DeletionType.VALUATION_DELETION.getCode());
  649. deletionInfoDO.setDeletionDate(tradeDate);
  650. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  651. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  652. }
  653. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  654. }
  655. continue;
  656. }else{
  657. //防止频率变更导致数据异常,需要把当前日期下所在的频率全部无效掉
  658. if(StringUtil.isNotEmpty(valuationDOS)){
  659. List<String> deleteTradeDateList = new ArrayList<>();
  660. for(int idx=0;idx < valuationDOS.size()-1 ; idx++){
  661. FundPositionDetailDO valautionDO = valuationDOS.get(idx);
  662. String tradeDate = DateUtils.format(valautionDO.getValuationDate(),DateUtils.YYYY_MM_DD);
  663. deleteTradeDateList.add(tradeDate);
  664. }
  665. deletionInfoMapper.deleteDeletionRemark(fundId,DeletionType.VALUATION_DELETION.getCode(),deleteTradeDateList);
  666. }
  667. }
  668. //不包含的话,默认取每周的最后一个交易日作为周净值日期
  669. List<TradeDateDO> tradeDateDOS = tradeListMap.get(weekOfYear);
  670. String tradeDate = null;
  671. if(tradeDateDOS.size() > 0){
  672. tradeDate = DateUtils.format(tradeDateDOS.get(tradeDateDOS.size()-1).getTradeDate(),DateUtils.YYYY_MM_DD);
  673. }
  674. if(tradeDateDOList.size() <= 3){
  675. continue;
  676. }
  677. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  678. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  679. continue;
  680. }
  681. tradeDateList.add(tradeDate);
  682. }
  683. //写入缺失信息表
  684. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.VALUATION_DELETION.getCode());
  685. }
  686. if(Frequency.MONTH == Frequency.getFrequencyByCode(fundReportFrequencyDO.getValuationFrequency())){
  687. Map<String,List<FundPositionDetailDO>> valuationListMap = fundPositionDetailDOList.stream().collect(Collectors.groupingBy(e -> DateUtils.format(e.getValuationDate(),DateUtils.YYYY_MM_DD)));
  688. TreeMap<String,List<FundPositionDetailDO>> monthNavListMap = new TreeMap<>();
  689. //按周数整合
  690. for(String priceDate : valuationListMap.keySet()){
  691. String yearMonth = priceDate.substring(0,7);
  692. if(monthNavListMap.containsKey(yearMonth)){
  693. List<FundPositionDetailDO> fundPositionDetailDOS = monthNavListMap.get(yearMonth);
  694. fundPositionDetailDOS.addAll(valuationListMap.get(priceDate));
  695. monthNavListMap.put(yearMonth,fundPositionDetailDOS);
  696. }else{
  697. List<FundPositionDetailDO> fundPositionDetailDOS = new ArrayList<>();
  698. fundPositionDetailDOS.addAll(valuationListMap.get(priceDate));
  699. monthNavListMap.put(yearMonth,fundPositionDetailDOS);
  700. }
  701. }
  702. Map<String,List<TradeDateDO>> tradeListMap = tradeDateDOList.stream().collect(Collectors.groupingBy(e -> e.getYearmonth()));
  703. for(String yearMonth : tradeListMap.keySet()){
  704. //本月的数据不考虑
  705. String thisMonth = DateUtils.format(new Date(),DateUtils.YYYY_MM);
  706. if(yearMonth.equals(thisMonth)){
  707. continue;
  708. }
  709. List<FundPositionDetailDO> fundPositionDetailDOS = monthNavListMap.get(yearMonth);
  710. if(monthNavListMap.containsKey(yearMonth)){
  711. List<String> batchUpdateTradeList = new ArrayList<>();
  712. for(TradeDateDO tradeDateDO : tradeListMap.get(yearMonth)){
  713. String tradeDate = DateUtils.format(tradeDateDO.getTradeDate(),DateUtils.YYYY_MM_DD);
  714. batchUpdateTradeList.add(tradeDate);
  715. }
  716. if(batchUpdateTradeList.size() > 0){
  717. List<DeletionInfoDO> batchUpdateDeletionInfoDO = new ArrayList<>();
  718. for(String tradeDate : batchUpdateTradeList){
  719. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  720. deletionInfoDO.setFundId(fundId);
  721. deletionInfoDO.setDeletionType(DeletionType.VALUATION_DELETION.getCode());
  722. deletionInfoDO.setDeletionDate(tradeDate);
  723. deletionInfoDO.setRemark(DeletionType.NO_DELETION.getInfo());
  724. batchUpdateDeletionInfoDO.add(deletionInfoDO);
  725. }
  726. deletionInfoMapper.batchUpdateRemark(batchUpdateDeletionInfoDO);
  727. }
  728. continue;
  729. }else{
  730. //防止频率变更导致数据异常,需要把当前日期下所在的频率全部无效掉
  731. if(StringUtil.isNotEmpty(fundPositionDetailDOS)){
  732. List<String> deleteTradeDateList = new ArrayList<>();
  733. for(FundPositionDetailDO fundPositionDetailDO : fundPositionDetailDOS){
  734. String tradeDate = DateUtils.format(fundPositionDetailDO.getValuationDate(),DateUtils.YYYY_MM_DD);
  735. deleteTradeDateList.add(tradeDate);
  736. }
  737. deletionInfoMapper.deleteDeletionRemark(fundId,DeletionType.VALUATION_DELETION.getCode(),deleteTradeDateList);
  738. }
  739. }
  740. //不包含的话,默认取每月的最后一个交易日作为周净值日期
  741. List<TradeDateDO> tradeDateDOS = tradeListMap.get(yearMonth);
  742. String tradeDate = null;
  743. if(tradeDateDOS.size() > 0){
  744. tradeDate = DateUtils.format(tradeDateDOS.get(tradeDateDOS.size()-1).getTradeDate(),DateUtils.YYYY_MM_DD);
  745. }
  746. if(tradeDateDOList.size() <= 3){
  747. continue;
  748. }
  749. TradeDateDO tradeDateDO = tradeDateDOList.get(tradeDateDOList.size()-3);
  750. if(tradeDateDO.getTradeDate().compareTo(DateUtils.parse(tradeDate,DateUtils.YYYY_MM_DD)) < 0){
  751. continue;
  752. }
  753. tradeDateList.add(tradeDate);
  754. }
  755. //写入缺失信息表
  756. saveDeletionInfoDO(channelId,fundId,tradeDateList,DeletionType.VALUATION_DELETION.getCode());
  757. }
  758. }
  759. private void saveDeletionInfoDO(Integer channelId,String fundId, List<String> tradeDateList, Integer code) {
  760. if(tradeDateList.size() < 1){
  761. return;
  762. }
  763. List<DeletionInfoDO> oldDeletionDOList = deletionInfoMapper.getDeletionInfoDO(channelId,fundId,code,tradeDateList);
  764. if(oldDeletionDOList != null && oldDeletionDOList.size() > 0){
  765. for(DeletionInfoDO oldDeletionDO : oldDeletionDOList){
  766. oldDeletionDO.setIsvalid(1);
  767. oldDeletionDO.setUpdateTime(DateUtils.getNowDate());
  768. }
  769. deletionInfoMapper.batchUpdateDeletionInfoDO(oldDeletionDOList);
  770. }
  771. List<String> oldTradeDateList = oldDeletionDOList.stream().map(e -> e.getDeletionDate()).collect(Collectors.toList());
  772. List<String> insertTradeDateList = new ArrayList<>();
  773. for(String tradeDate : tradeDateList){
  774. if(oldTradeDateList.contains(tradeDate)){
  775. continue;
  776. }
  777. insertTradeDateList.add(tradeDate);
  778. }
  779. if(insertTradeDateList.size() > 0){
  780. List<DeletionInfoDO> insertDeletionInfoDO = new ArrayList<>();
  781. for(String tradeDate : insertTradeDateList){
  782. DeletionInfoDO deletionInfoDO = new DeletionInfoDO();
  783. deletionInfoDO.setFundId(fundId);
  784. deletionInfoDO.setChannelId(channelId);
  785. deletionInfoDO.setDeletionType(code);
  786. deletionInfoDO.setDeletionDate(tradeDate);
  787. deletionInfoDO.setIsvalid(1);
  788. deletionInfoDO.setIsSend(0);
  789. deletionInfoDO.setUpdateTime(DateUtils.getNowDate());
  790. deletionInfoDO.setCreateTime(DateUtils.getNowDate());
  791. insertDeletionInfoDO.add(deletionInfoDO);
  792. }
  793. deletionInfoMapper.batchSaveDeletionInfoDO(insertDeletionInfoDO);
  794. }
  795. }
  796. }