From ad597f433afb0e4ead989aa8a30133fe40d3b98c Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Thu, 02 Oct 2025 00:05:41 +0800
Subject: [PATCH] 1

---
 trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java |   42 ++++++++++++++++++++----------------------
 1 files changed, 20 insertions(+), 22 deletions(-)

diff --git a/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java b/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java
index c3230f7..50d8aef 100644
--- a/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java
+++ b/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java
@@ -16,12 +16,14 @@
 import com.yami.trading.bean.item.domain.Item;
 import com.yami.trading.bean.item.dto.ItemDTO;
 import com.yami.trading.bean.item.dto.ItemLeverageDTO;
+import com.yami.trading.bean.robot.domain.Robot;
 import com.yami.trading.common.util.ApplicationContextUtils;
 import com.yami.trading.common.util.MarketOpenChecker;
 import com.yami.trading.common.util.StringUtils;
 import com.yami.trading.dao.item.ItemMapper;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.cache.annotation.CacheEvict;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
@@ -127,6 +129,13 @@
         return super.baseMapper.selectOne(queryWrapper);
     }
 
+    public Item findCurrBySymbol(String symbol) {
+        LambdaQueryWrapper<Item> queryWrapper = new LambdaQueryWrapper<Item>()
+                .eq(Item::getSymbol, symbol)
+                .last("LIMIT 1");
+        return super.baseMapper.selectOne(queryWrapper);
+    }
+
 
     /**
      * 根据id查询
@@ -179,22 +188,8 @@
         return super.removeById(id);
     }
 
-    // 清除 list() 方法的缓存(关键:与@Cached的name和key一致)
-    /*@CacheEvict(cacheNames = ITEM_CACHE, key = "'all'")
-    public void clearListCache() {
-        log.info("已清除 list() 方法的缓存");
-    }*/
-
     public void reloadListAndCache() {
-        // 步骤1:清除 list() 方法的原有缓存(确保重新查询)
-        //clearListCache();
-
-        // 步骤2:重新调用 list() 方法,此时会执行数据库查询,且@Cached会自动更新缓存
-        //List<Item> freshList = list();
-
-        // 步骤3(可选):如果需要同步更新 init() 方法中的 itemCache,重新调用 init()
         init();
-        log.info("初始化init()");
     }
 
     /**
@@ -252,7 +247,7 @@
      * @return
      */
     public boolean isContractTrading(Item item) {
-        item = getById(item.getUuid());
+        item = findBySymbol(item.getSymbol());
         //虚拟币新币才判断
         if (item.getType().equals(Item.cryptos) && (item.getCurrencyType() != null && item.getCurrencyType() == 1)) {
             if (item.getTradeType() != null && item.getTradeType().equals("0")) {
@@ -264,15 +259,18 @@
 
     /**
      * 是否停牌状态
-     * @param item
      * @return
      */
-    public boolean isSuspended(Item item) {
-        item = getById(item.getUuid());
-        //虚拟币新币才判断
-        if (item.getType().equals(Item.cryptos) && (item.getCurrencyType() != null && item.getCurrencyType() == 1)) {
-            if (item.getStatus() != null && item.getStatus() == 0) {
-                return true;
+    public boolean isSuspended(String symbol) {
+        //Item item = findBySymbol(symbol);
+        Item item = getOne(new LambdaQueryWrapper<Item>().eq(Item::getSymbol, symbol));
+        if (item != null) {
+            //虚拟币新币才判断
+            if (item.getType().equals(Item.cryptos) /*&& (item.getCurrencyType() != null && item.getCurrencyType() == 1)*/) {
+                //item = getById(item.getUuid());
+                if (item.getStatus() != null && item.getStatus() == 0) {
+                    return true;
+                }
             }
         }
         return false;

--
Gitblit v1.9.3