From cb0f6d8ca263066e4cc0a4fa5f089e516f5aa909 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 05 Sep 2025 18:40:29 +0800
Subject: [PATCH] C2C修复
---
trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java | 21 +++++++++++++++++++--
1 files changed, 19 insertions(+), 2 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 cdb02e8..c3230f7 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,13 +16,11 @@
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.common.exception.YamiShopBindException;
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.checkerframework.checker.units.qual.A;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@@ -181,6 +179,23 @@
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()");
+ }
/**
* 获取品种精度
@@ -237,6 +252,7 @@
* @return
*/
public boolean isContractTrading(Item item) {
+ item = getById(item.getUuid());
//虚拟币新币才判断
if (item.getType().equals(Item.cryptos) && (item.getCurrencyType() != null && item.getCurrencyType() == 1)) {
if (item.getTradeType() != null && item.getTradeType().equals("0")) {
@@ -252,6 +268,7 @@
* @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) {
--
Gitblit v1.9.3