From ecca9ab70a9a87bcb60977c92fbf81053b8fc1bb Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期三, 04 九月 2024 09:17:55 +0800
Subject: [PATCH] 新增优化

---
 ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/UserServiceImpl.java |  101 +++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 91 insertions(+), 10 deletions(-)

diff --git a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/UserServiceImpl.java b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/UserServiceImpl.java
index 59b8464..6a0a257 100644
--- a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/UserServiceImpl.java
+++ b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/UserServiceImpl.java
@@ -22,6 +22,7 @@
 import java.time.Year;
 import java.time.temporal.TemporalAdjusters;
 import java.util.ArrayList;
+import java.util.Iterator;
 import java.util.List;
 
 /**
@@ -45,24 +46,36 @@
         List<UserTrendsVO> userTrendsList = baseMapper.userTrends(city);
         return null == userTrendsList || userTrendsList.isEmpty() ? new ArrayList<>() : userTrendsList;
     }
+    @Override
+    public List<UserTrendsVO> userTrends1(List<String> city,List<Integer> userIds) {
+        if (userIds.isEmpty()){
+            return new ArrayList<>();
+        }
+        List<UserTrendsVO> userTrendsList = baseMapper.userTrends1(city,userIds);
+        return null == userTrendsList || userTrendsList.isEmpty() ? new ArrayList<>() : userTrendsList;
+    }
 
     @Override
     public UserDataCountVO userDataCount(UserDataCountRequest userDataCountRequest) {
         List<String> cityList = userDataCountRequest.getCityList();
         String type = userDataCountRequest.getCountType();
-        LambdaQueryChainWrapper<User> userWrapper = lambdaQuery().eq(User::getIsDelete, 0);
+        LambdaQueryChainWrapper<User> userWrapper = lambdaQuery().eq(User::getIsDelete, 0).isNotNull(User::getPhone);
         if (null != cityList && !cityList.isEmpty()) {
             userWrapper.in(User::getCityCode, cityList);
         }
         List<User> userList = userWrapper.list();
+
         // 判断用户是否在管辖城市内下过订单
-        for (User user : userList) {
-            Integer userId = user.getId();
-            R<Boolean> r = orderClient.orderByUserId(userId);
-            if (!r.getData()) {
-                userList.remove(user);
-            }
-        }
+//        Iterator<User> iterator = userList.iterator();
+//        while (iterator.hasNext()) {
+//            User user = iterator.next();
+//            Integer userId = user.getId();
+//            R<Boolean> r = orderClient.orderByUserId(userId);
+//            if (!r.getData()) {
+//                iterator.remove(); // 安全地移除元素
+//            }
+//        }
+
         Integer userNumber = userList.size();
         // 用户总量
         // 计算当前季度时间所包含时间
@@ -77,7 +90,7 @@
         // 结果数据封装
         Long increaseNumber;
         // 交易额
-        BigDecimal totalMoney = orderClient.tradeMoney(cityList, userDataCountRequest.getCountType()).getData();
+        BigDecimal totalMoney = orderClient.tradeMoney(new MoneyQueryRequest(cityList,userDataCountRequest.getCountType())).getData();
         BigDecimal withdrawalTotalMoney = withdrawClient.withdrawalTotalMoney(new MoneyQueryRequest(cityList, type))
                 .getData();
         if (OrderConstants.QUARTER.equals(type)) {
@@ -87,7 +100,7 @@
             if (null != cityList && !cityList.isEmpty()) {
                 wrapper.in(User::getCityCode, cityList);
             }
-            increaseNumber = wrapper.eq(User::getIsDelete, 0).count();
+            increaseNumber = wrapper.eq(User::getIsDelete, 0).isNotNull(User::getPhone).count();
         } else if (OrderConstants.YEAR.equals(type)) {
             // 用户增长数
             increaseNumber = baseMapper.increaseNumberByYear(cityList);
@@ -105,6 +118,74 @@
         return new UserDataCountVO(userNumber, increaseNumber, totalMoney, withdrawalTotalMoney);
     }
 
+
+    @Override
+    public UserDataCountVO userDataCount1(UserDataCountRequest userDataCountRequest,List<Integer> userIds) {
+        List<String> cityList = userDataCountRequest.getCityList();
+        String type = userDataCountRequest.getCountType();
+        if (userIds.isEmpty()){
+            return new UserDataCountVO(null,null,null,null);
+        }
+
+        LambdaQueryChainWrapper<User> userWrapper = lambdaQuery().eq(User::getIsDelete, 0).isNotNull(User::getPhone).in(!userIds.isEmpty(),User::getId,userIds);
+//        if (null != cityList && !cityList.isEmpty()) {
+//            userWrapper.in(User::getCityCode, cityList);
+//        }
+        List<User> userList = userWrapper.list();
+
+        // 判断用户是否在管辖城市内下过订单
+        Iterator<User> iterator = userList.iterator();
+        while (iterator.hasNext()) {
+            User user = iterator.next();
+            Integer userId = user.getId();
+            R<Boolean> r = orderClient.orderByUserId(userId);
+            if (!r.getData()) {
+                iterator.remove(); // 安全地移除元素
+            }
+        }
+
+        Integer userNumber = userList.size();
+        // 用户总量
+        // 计算当前季度时间所包含时间
+        int currentYear = Year.now().getValue();
+        // 获取当前月份
+        Month currentMonth = LocalDate.now().getMonth();
+        // 计算当前季度的开始时间和结束时间
+        LocalDate startDate = LocalDate.of(currentYear, getStartMonthOfQuarter(currentMonth), 1);
+        LocalDate endDate = startDate.plusMonths(2).with(TemporalAdjusters.lastDayOfMonth());
+        String startDateStr = String.valueOf(startDate);
+        String endDateStr = String.valueOf(endDate);
+        // 结果数据封装
+        Long increaseNumber;
+        // 交易额
+        BigDecimal totalMoney = orderClient.tradeMoney(new MoneyQueryRequest(cityList,userDataCountRequest.getCountType())).getData();
+        BigDecimal withdrawalTotalMoney = withdrawClient.withdrawalTotalMoney(new MoneyQueryRequest(cityList, type))
+                .getData();
+        if (OrderConstants.QUARTER.equals(type)) {
+            // 用户增长数
+            LambdaQueryChainWrapper<User> wrapper = lambdaQuery().ge(User::getCreateTime, startDateStr)
+                    .le(User::getCreateTime, endDateStr).in(User::getId,userIds);
+//            if (null != cityList && !cityList.isEmpty()) {
+//                wrapper.in(User::getCityCode, cityList);
+//            }
+            increaseNumber = wrapper.eq(User::getIsDelete, 0).isNotNull(User::getPhone).count();
+        } else if (OrderConstants.YEAR.equals(type)) {
+            // 用户增长数
+            increaseNumber = baseMapper.increaseNumberByYear1(cityList,userIds);
+        } else if (OrderConstants.MONTH.equals(type)) {
+            // 用户增长数
+            increaseNumber = baseMapper.increaseNumberByMonth1(cityList,userIds);
+        } else {
+            // 数量初始化
+            increaseNumber = 0L;
+        }
+        // 查询结果判断
+        increaseNumber = null == increaseNumber ? 0L : increaseNumber;
+        totalMoney = null == totalMoney ? BigDecimal.ZERO : totalMoney;
+        withdrawalTotalMoney = null == withdrawalTotalMoney ? BigDecimal.ZERO : withdrawalTotalMoney;
+        return new UserDataCountVO(userNumber, increaseNumber, totalMoney, withdrawalTotalMoney);
+    }
+
     /**
      * 根据当前月份获取当前季度的开始月份
      */

--
Gitblit v1.7.1