From 86587c1ffa0bdfa2a171dce96540c7617dd44dec Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 28 Jan 2026 18:33:54 +0800
Subject: [PATCH] 1

---
 src/main/java/com/nq/service/impl/UserServiceImpl.java |   24 ++++++++++++++++++++----
 1 files changed, 20 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserServiceImpl.java b/src/main/java/com/nq/service/impl/UserServiceImpl.java
index 6b62b34..5950649 100644
--- a/src/main/java/com/nq/service/impl/UserServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserServiceImpl.java
@@ -1528,9 +1528,11 @@
         BigDecimal sh_amt = user.getEnableAmt();
 
         BigDecimal sh_amt_back = new BigDecimal("0");
+        BigDecimal enaleWithdrawAmt = user.getEnaleWithdrawAmt();
         //0 加钱  1 减钱 2虚拟加钱
         if (direction.intValue() == 0||direction.intValue()==2) {
             sh_amt_back = sh_amt.add(new BigDecimal(amt));
+            enaleWithdrawAmt  = enaleWithdrawAmt.add(new BigDecimal(amt));
         } else if (direction.intValue() == 1) {
 
             if (sh_amt.compareTo(new BigDecimal(amt)) == -1) {
@@ -1541,6 +1543,7 @@
             return ServerResponse.createByErrorMsg("不存在此操作");
         }
         user.setEnableAmt(sh_amt_back);
+        user.setEnaleWithdrawAmt(enaleWithdrawAmt);
 
 //        BigDecimal hk_amt = user.getHkAmt();
 //
@@ -1827,11 +1830,24 @@
         PositionVO positionVO = this.iUserPositionService.findUserPositionAllProfitAndLose(user.getId());
         userInfoVO.setAllFreezAmt(positionVO.getAllFreezAmt());
         BigDecimal allProfitAndLose = positionVO.getAllProfitAndLose();
-        userInfoVO.setAllProfitAndLose(allProfitAndLose);
-
-//        BigDecimal userAllAmt = user.getUserAmt();
+        BigDecimal profitAndLose = this.userPositionMapper.CountPositionAllProfitAndLoseByUserId(user.getId());
         BigDecimal userAllAmt = user.getEnableAmt();
-        userAllAmt = userAllAmt.add(allProfitAndLose);
+
+
+        // 初始化总盈亏为0
+        BigDecimal totalProfitAndLose = BigDecimal.ZERO;
+
+        // 累加各个盈亏(安全处理null值)
+        if (allProfitAndLose != null) {
+            totalProfitAndLose = totalProfitAndLose.add(allProfitAndLose);
+        }
+        if (profitAndLose != null) {
+            totalProfitAndLose = totalProfitAndLose.add(profitAndLose);
+        }
+        userInfoVO.setAllProfitAndLose(totalProfitAndLose);
+        if(null != allProfitAndLose){
+            userAllAmt = userAllAmt.add(allProfitAndLose);
+        }
 
 
         userInfoVO.setEnableIndexAmt(user.getEnableIndexAmt());

--
Gitblit v1.9.3