From 082b9ab8643bc5e81f2e70b8e9400fdaba62e686 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期三, 03 九月 2025 17:19:18 +0800
Subject: [PATCH] 修改小程序首页查询重复bug

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java |   22 ++++++++++++----------
 1 files changed, 12 insertions(+), 10 deletions(-)

diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java
index 66eb669..a33ba2a 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java
@@ -14,19 +14,16 @@
 import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.common.security.service.TokenService;
-import com.ruoyi.order.api.model.TExchangeOrder;
 import com.ruoyi.order.api.model.TShoppingOrder;
 import com.ruoyi.order.api.model.TShoppingOrderRefund;
 import com.ruoyi.order.api.query.ShoppingOrderQuery;
 import com.ruoyi.order.api.query.TActivityStatisticsQuery;
-import com.ruoyi.order.api.vo.ChargingOrderVO;
 import com.ruoyi.order.api.vo.TActivityStatisticslVO;
 import com.ruoyi.order.api.vo.TActivityVO;
 import com.ruoyi.order.dto.*;
 import com.ruoyi.order.mapper.TShoppingOrderMapper;
 import com.ruoyi.order.service.TShoppingOrderRefundService;
 import com.ruoyi.order.service.TShoppingOrderService;
-import com.ruoyi.order.util.RedisLock;
 import com.ruoyi.other.api.domain.TCoupon;
 import com.ruoyi.other.api.domain.TGoods;
 import com.ruoyi.other.api.feignClient.CouponClient;
@@ -38,7 +35,8 @@
 import com.ruoyi.payment.api.model.WxPaymentRefundModel;
 import com.ruoyi.payment.api.vo.AliQueryOrder;
 import com.ruoyi.payment.api.vo.NotifyV3PayDecodeRespBody;
-import io.seata.spring.annotation.GlobalTransactional;
+import org.redisson.api.RLock;
+import org.redisson.api.RedissonClient;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.stereotype.Service;
@@ -52,6 +50,7 @@
 import java.time.LocalDateTime;
 import java.time.format.DateTimeFormatter;
 import java.util.*;
+import java.util.concurrent.TimeUnit;
 import java.util.stream.Collectors;
 
 /**
@@ -92,6 +91,9 @@
 
     @Autowired
     public RedisTemplate redisTemplate;
+
+    @Autowired
+    private RedissonClient redissonClient;
 
 
 
@@ -503,9 +505,9 @@
         //商品
         if(shoppingOrder.getOrderType() == 1){
             //redis锁 和支付使用同一个锁
-            RedisLock redisLock = new RedisLock(redisTemplate, "SHOPPING_GOODS_LOCK", 5, 30000);
+            RLock lock = redissonClient.getLock("SHOPPING_GOODS_LOCK");
             try {
-                redisLock.lock();
+                lock.tryLock(5, 30, TimeUnit.SECONDS);
                 TGoods goods = goodsClient.getGoodsById(shoppingOrder.getGoodsId()).getData();
                 Integer inventory = goods.getInventory();
                 if(-1 != inventory){
@@ -516,15 +518,15 @@
                 e.printStackTrace();
             }finally {
                 //解锁
-                redisLock.unlock();
+                lock.unlock();
             }
         }
         //优惠券
         if(shoppingOrder.getOrderType() == 2){
             //redis锁 和支付使用同一个锁
-            RedisLock redisLock = new RedisLock(redisTemplate, "SHOPPING_COUPON_LOCK", 5, 30000);
+            RLock lock = redissonClient.getLock("SHOPPING_COUPON_LOCK");
             try {
-                redisLock.lock();
+                lock.tryLock(5, 30, TimeUnit.SECONDS);
                 TCoupon coupon = couponClient.getCouponById1(shoppingOrder.getCouponId()).getData();
                 Integer inventory = coupon.getInventoryQuantity();
                 if(-1 != inventory){
@@ -535,7 +537,7 @@
                 e.printStackTrace();
             }finally {
                 //解锁
-                redisLock.unlock();
+                lock.unlock();
             }
         }
         return AjaxResult.success();

--
Gitblit v1.7.1