From 54b7b7f921297e431ab06f6fd05c59f6c377f55d Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Sat, 11 Oct 2025 18:38:30 +0800
Subject: [PATCH] 调整值

---
 trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java |   31 ++++++++++++++++++++++++-------
 1 files changed, 24 insertions(+), 7 deletions(-)

diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
index b076e29..29edd48 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
@@ -37,10 +37,10 @@
     @Autowired
     private NamedParameterJdbcOperations namedParameterJdbcTemplate;
 
-/*    public static void main(String[] args) {
-        BigDecimal a = BigDecimal.valueOf(0.006);
-        BigDecimal b = BigDecimal.valueOf(3600);
-        BigDecimal c = a.divide(b, 6, BigDecimal.ROUND_HALF_UP);
+    /*public static void main(String[] args) {
+        BigDecimal a = BigDecimal.valueOf(0.003);
+        BigDecimal b = BigDecimal.valueOf(7200);
+        BigDecimal c = a.divide(b, 10, BigDecimal.ROUND_HALF_UP);
         System.out.println(c);
     }*/
     @Override
@@ -179,7 +179,6 @@
 
     @Override
     public void saveOneByHuoBi(String symbol, String line) {
-        RequestDataHelper.set("symbol", symbol);
         List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 2,
                 0);
         if (list == null || list.isEmpty()) {
@@ -195,7 +194,24 @@
                 kline.setHigh(kline.getHigh().add(currentValue));
                 kline.setAdjusted(true);
 
-                BigDecimal last = AdjustmentValueCache.getLastValue().get(symbol);
+
+                Kline lastOne = null;
+
+                List<Kline> lastList = this.find(symbol, line, 1);
+                if (lastList.size() > 0) {
+                    lastOne = list.get(0);
+                }
+                if (lastOne != null) {
+                    BigDecimal diff = kline.getOpen().subtract(lastOne.getClose());
+                    if (diff.compareTo(BigDecimal.ZERO) > 0) { //补差
+                        kline.setOpen(kline.getOpen().subtract(diff));
+                        kline.setLow(kline.getLow().subtract(diff));
+                    } else if (diff.compareTo(BigDecimal.ZERO) < 0) {
+                        kline.setOpen(kline.getOpen().subtract(diff));
+                        kline.setHigh(kline.getHigh().subtract(diff));
+                    }
+                }
+                /*BigDecimal last = AdjustmentValueCache.getLastValue().get(symbol);
                 if (last != null && last.compareTo(BigDecimal.ZERO) > 0) {
                     BigDecimal adj = currentValue.subtract(last);
                     if (adj.compareTo(BigDecimal.ZERO) > 0) { //递增
@@ -207,9 +223,10 @@
                     }
                 } else {
                     AdjustmentValueCache.getLastValue().put(symbol, currentValue);
-                }
+                }*/
             }
         }
+        RequestDataHelper.set("symbol", symbol);
         klineDBService.save(kline);
         KlineTimeObject timeObject = DataCache.getKline(symbol, line);
         if (timeObject == null) {

--
Gitblit v1.9.3