From 74e5a0efcda0eff0f23037c3439ef5405bafe922 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Sun, 08 Mar 2026 17:41:26 +0800
Subject: [PATCH] 1

---
 trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java          |    9 ++++
 trading-order-bean/src/main/java/com/yami/trading/bean/data/dto/BeforeClose.java                |    2 +
 trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java |   30 +++++++-------
 trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBService.java       |    2 
 trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java   |   24 ++++++++++--
 5 files changed, 46 insertions(+), 21 deletions(-)

diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java
index 91b57a7..3eea33f 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.yami.trading.bean.data.domain.Kline;
+import com.yami.trading.bean.data.domain.Realtime;
 import com.yami.trading.bean.data.dto.BeforeClose;
 import com.yami.trading.bean.ico.domain.Ico;
 import com.yami.trading.bean.item.domain.Item;
@@ -10,6 +11,7 @@
 import com.yami.trading.common.util.DateUtils;
 import com.yami.trading.common.web.ResultObject;
 import com.yami.trading.huobi.data.AdjustmentValueCache;
+import com.yami.trading.huobi.data.DataCache;
 import com.yami.trading.huobi.data.internal.DataDBService;
 import com.yami.trading.huobi.data.internal.KlineService;
 import com.yami.trading.service.data.DataService;
@@ -181,7 +183,12 @@
 
             //if (line.equalsIgnoreCase(Kline.PERIOD_15MIN) || line.equalsIgnoreCase(Kline.PERIOD_30MIN) || line.equalsIgnoreCase(Kline.PERIOD_60MIN)) {
                 if (i == data.size() - 1) {
-                    BeforeClose beforeClose = dataDBService.getBeforeClose(kline.getSymbol(), line, ts);
+                    //获取当前价格
+                    Realtime realtime = DataCache.getLatestRealTime(symbol);
+                    if (realtime != null) {
+                        map.put("close", realtime.getClose().setScale(decimal, RoundingMode.HALF_UP));
+                    }
+                    BeforeClose beforeClose = dataDBService.getBeforeClose(kline.getSymbol(), line, ts, realtime);
                     if (beforeClose != null) {
                         map.put("high", beforeClose.getMaxClose().setScale(decimal, RoundingMode.HALF_UP));
                         map.put("low", beforeClose.getMinClose().setScale(decimal, RoundingMode.HALF_UP));
diff --git a/trading-order-bean/src/main/java/com/yami/trading/bean/data/dto/BeforeClose.java b/trading-order-bean/src/main/java/com/yami/trading/bean/data/dto/BeforeClose.java
index 47f3b45..50154c3 100644
--- a/trading-order-bean/src/main/java/com/yami/trading/bean/data/dto/BeforeClose.java
+++ b/trading-order-bean/src/main/java/com/yami/trading/bean/data/dto/BeforeClose.java
@@ -16,5 +16,7 @@
 
 	private BigDecimal minClose = BigDecimal.ZERO;
 
+	private Long ts = 0L;
+
 
 }
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBService.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBService.java
index 9b74b50..c84c974 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBService.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBService.java
@@ -27,7 +27,7 @@
 	/**
 	 * 数据库根据时间查询
 	 */
-	public BeforeClose getBeforeClose(String symbol, String line, Long ts);
+	public BeforeClose getBeforeClose(String symbol, String line, Long ts, Realtime realtime);
 
 	/**
 	 * 缓存数据库前24小时最高最低价格
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java
index a0518b9..9ec30ce 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java
@@ -142,9 +142,10 @@
         return realtime;
     }
 
-    public BeforeClose getBeforeClose(String symbol, String line, Long ts) {
+    public BeforeClose getBeforeClose(String symbol, String line, Long ts, Realtime realtime) {
         BeforeClose beforeClose = (BeforeClose) redisTemplate.opsForValue().get(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line);
-        if (beforeClose == null) {
+        //超出时间重新计算
+        if (beforeClose == null || ts > beforeClose.getTs()) {
             // 直接获取当前时间的毫秒级时间戳(系统默认时区,但值是全球统一的)
             long currentTimeStamp = System.currentTimeMillis();
 
@@ -155,7 +156,8 @@
                     .eq("symbol", symbol) // 直接写数据库字段名(需和表字段一致)
                     .ge("ts", ts)
                     .le("ts", currentTimeStamp)
-                    .select("MAX(close) as maxClose", "MIN(close) as minClose");
+                    .select("MAX(CAST(close AS DECIMAL(10,4))) as maxClose",
+                            "MIN(CAST(close AS DECIMAL(10,4))) as minClose");
             // 4. 执行聚合查询,用selectMap接收结果(键值对:maxClose/minClose -> 对应值)
             Map<String, Object> resultMap = realtimeService.getMap(queryWrapper);
             RequestDataHelper.clear();
@@ -165,8 +167,22 @@
             }
             beforeClose.setMaxClose(convertToBigDecimal(resultMap.get("maxClose")));
             beforeClose.setMinClose(convertToBigDecimal(resultMap.get("minClose")));
-            redisTemplate.opsForValue().set(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line, beforeClose , 10 , TimeUnit.SECONDS);
+            beforeClose.setTs(ts);
+            redisTemplate.opsForValue().set(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line, beforeClose);
         }
+
+
+        if (realtime != null) {
+            if (realtime.getClose().compareTo(beforeClose.getMaxClose()) > 0) {
+                beforeClose.setMaxClose(realtime.getClose());
+                redisTemplate.opsForValue().set(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line, beforeClose);
+            }
+            if (realtime.getClose().compareTo(beforeClose.getMinClose()) < 0) {
+                beforeClose.setMinClose(realtime.getClose());
+                redisTemplate.opsForValue().set(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line, beforeClose);
+            }
+        }
+        System.out.println("realtime.getClose():" + realtime.getClose() + "==" + beforeClose);
         return beforeClose;
     }
 
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java
index 61dfeeb..9d92628 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java
@@ -153,29 +153,29 @@
                         param.put("size", 1440);
                     }
                     if (Kline.PERIOD_5MIN.equals(period)) {
-                        param.put("size", 576);
+                        param.put("size", 2000);
                     }
                     if (Kline.PERIOD_15MIN.equals(period)) {
-                        param.put("size", 576);
+                        param.put("size", 2000);
                     }
                     if (Kline.PERIOD_30MIN.equals(period)) {
-                        param.put("size", 576);
+                        param.put("size", 2000);
                     }
                     if (Kline.PERIOD_60MIN.equals(period)) {
-                        param.put("size", 576);
+                        param.put("size", 2000);
                     }
 
                     if (Kline.PERIOD_4HOUR.equals(period)) {
-                        param.put("size", 576);
+                        param.put("size", 200);
                     }
                     if (Kline.PERIOD_1DAY.equals(period)) {
-                        param.put("size", 500);
+                        param.put("size", 2000);
                     }
                     if (Kline.PERIOD_1MON.equals(period)) {
-                        param.put("size", 500);
+                        param.put("size", 2000);
                     }
                     if (Kline.PERIOD_1WEEK.equals(period)) {
-                        param.put("size", 500);
+                        param.put("size", 2000);
                     }
 
                 } else {
@@ -237,29 +237,29 @@
                     param.put("size", 1440);
                 }
                 if (Kline.PERIOD_5MIN.equals(period)) {
-                    param.put("size", 576);
+                    param.put("size", 2000);
                 }
                 if (Kline.PERIOD_15MIN.equals(period)) {
-                    param.put("size", 576);
+                    param.put("size", 2000);
                 }
                 if (Kline.PERIOD_30MIN.equals(period)) {
-                    param.put("size", 576);
+                    param.put("size", 2000);
                 }
                 if (Kline.PERIOD_60MIN.equals(period)) {
-                    param.put("size", 576);
+                    param.put("size", 2000);
                 }
 
                 if (Kline.PERIOD_4HOUR.equals(period)) {
                     param.put("size", 576);
                 }
                 if (Kline.PERIOD_1DAY.equals(period)) {
-                    param.put("size", 500);
+                    param.put("size", 2000);
                 }
                 if (Kline.PERIOD_1MON.equals(period)) {
-                    param.put("size", 500);
+                    param.put("size", 2000);
                 }
                 if (Kline.PERIOD_1WEEK.equals(period)) {
-                    param.put("size", 500);
+                    param.put("size", 2000);
                 }
 
             } else {

--
Gitblit v1.9.3