websocketSerivce/src/main/java/org/example/task/BitgetStock.java
@@ -23,6 +23,7 @@ import org.example.pojo.bo.CurrencyBitgetBo; import org.example.server.impl.CurrencySerivceImpl; import org.example.util.ConverterUtil; import org.example.util.RedisUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @@ -89,9 +90,22 @@ }.getType()); getList.parallelStream().forEach(person -> person.setSymbol(StringUtils.remove(person.getSymbol(), "-"))); List<Currency> dbList = currencyService.list(new LambdaQueryWrapper<Currency>().eq(Currency::getSource,"bitget")); Set<String> symbolSet = getList.stream().map(CurrencyBitgetBo::getSymbol).collect(Collectors.toSet()); List<Currency> removeList = dbList.stream() .filter(currency -> !symbolSet.contains(currency.getSymbol())) .collect(Collectors.toList()); if(CollectionUtils.isNotEmpty(removeList)){ removeList.forEach(f->{ RedisUtil.delete("bitget"+f.getSymbol()); }); } // 获取数据库中已有的symbol列表 currencyService.remove(new LambdaQueryWrapper<Currency>().eq(Currency::getSource,"bitget")); // 比对接口返回的数据和数据库中已有的数据,找出新增的数据 List<Currency> saveList = getList.stream() .map(currency -> { Currency newCurrency = new Currency(); websocketSerivce/src/main/java/org/example/task/GateStock.java
@@ -10,11 +10,13 @@ import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.example.pojo.Currency; import org.example.pojo.bo.CurrencyBitgetBo; import org.example.pojo.bo.CurrencyGateBo; import org.example.pojo.bo.CurrencyMexcBo; import org.example.server.impl.CurrencySerivceImpl; import org.example.common.MarketDataClient; import org.example.util.ConverterUtil; import org.example.util.RedisUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @@ -74,6 +76,19 @@ getList.parallelStream().forEach(person -> person.setId(StringUtils.remove(person.getId(), "_"))); List<Currency> dbList = currencyService.list(new LambdaQueryWrapper<Currency>().eq(Currency::getSource, "gate")); Set<String> symbolSet = dbList.stream().map(Currency::getSymbol).collect(Collectors.toSet()); List<Currency> removeList = dbList.stream() .filter(currency -> !symbolSet.contains(currency.getSymbol())) .collect(Collectors.toList()); if(CollectionUtils.isNotEmpty(removeList)){ removeList.forEach(f->{ RedisUtil.delete("gate"+f.getSymbol()); }); } currencyService.remove(new LambdaQueryWrapper<Currency>().eq(Currency::getSource,"gate")); // 比对接口返回的数据和数据库中已有的数据,找出新增的数据 websocketSerivce/src/main/java/org/example/task/KucoinStock.java
@@ -14,6 +14,7 @@ import org.example.pojo.bo.CurrencyKucoin; import org.example.server.impl.CurrencySerivceImpl; import org.example.util.ConverterUtil; import org.example.util.RedisUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @@ -73,6 +74,18 @@ }.getType()); getList.parallelStream().forEach(person -> person.setSymbol(StringUtils.remove(person.getSymbol(), "-"))); List<Currency> dbList = currencyService.list(new LambdaQueryWrapper<Currency>().eq(Currency::getSource, "kucoin")); Set<String> symbolSet = dbList.stream().map(Currency::getSymbol).collect(Collectors.toSet()); List<Currency> removeList = dbList.stream() .filter(currency -> !symbolSet.contains(currency.getSymbol())) .collect(Collectors.toList()); if(CollectionUtils.isNotEmpty(removeList)){ removeList.forEach(f->{ RedisUtil.delete("kucoin"+f.getSymbol()); }); } currencyService.remove(new LambdaQueryWrapper<Currency>().eq(Currency::getSource,"kucoin")); // 比对接口返回的数据和数据库中已有的数据,找出新增的数据 websocketSerivce/src/main/java/org/example/task/MexcStock.java
@@ -14,6 +14,7 @@ import org.example.pojo.bo.CurrencyMexcBo; import org.example.server.impl.CurrencySerivceImpl; import org.example.util.ConverterUtil; import org.example.util.RedisUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @@ -74,7 +75,17 @@ Gson gson = new Gson(); List<CurrencyMexcBo> getList = gson.fromJson(symbolsJson, new TypeToken<List<CurrencyMexcBo>>() { }.getType()); List<Currency> dbList = currencyService.list(new LambdaQueryWrapper<Currency>().eq(Currency::getSource, "mexc")); Set<String> symbolSet = dbList.stream().map(Currency::getSymbol).collect(Collectors.toSet()); List<Currency> removeList = dbList.stream() .filter(currency -> !symbolSet.contains(currency.getSymbol())) .collect(Collectors.toList()); if(CollectionUtils.isNotEmpty(removeList)){ removeList.forEach(f->{ RedisUtil.delete("mexc"+f.getSymbol()); }); } currencyService.remove(new LambdaQueryWrapper<Currency>().eq(Currency::getSource,"mexc")); List<Currency> currencies = ConverterUtil.convertToList(getList, Currency.class); // 批量保存新增数据到数据库