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