From 5674594f06ec038a5ac1633b881518ffbd8c6c02 Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期一, 15 七月 2024 18:18:34 +0800 Subject: [PATCH] 修改bug --- ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java | 60 ++++++++++++++++++++++++++++-------------------------------- 1 files changed, 28 insertions(+), 32 deletions(-) diff --git a/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java b/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java index 0ecf080..5c36b86 100644 --- a/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java +++ b/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java @@ -18,6 +18,7 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.google.common.collect.Lists; import com.ruoyi.common.core.enums.GenderEnum; import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.core.utils.StringUtils; @@ -243,7 +244,6 @@ Member member1=this.getOne(wrapper1); if (member1==null){ - //创建新用户 String memberId = IdUtils.simpleUUID(); sysUser = new SysUser(); @@ -550,38 +550,32 @@ this.updateById(byId); LambdaQueryWrapper<MemberLevel> wrapper= Wrappers.lambdaQuery(); List<MemberLevel> list = memberLevelMapper.selectList(wrapper); - for (int i=0;i<list.size();i++){ - if (i==0){ - int ia = byId.getMoney().compareTo(list.get(0).getCumulativeConsumption()); - if (ia<0){ - byId.setLevel(0); - break; - } - } - if (i==list.size()-1){ - BigDecimal cumulative = list.get(i - 1).getCumulativeConsumption(); - BigDecimal cumulative1 = list.get(i).getCumulativeConsumption(); - if (cumulative.compareTo(byId.getMoney()) <= 0 && cumulative1.compareTo(byId.getMoney()) >= 0) { - byId.setLevel(list.get(i).getLevel()); - }else{ - if (cumulative1.compareTo(byId.getMoney())<=0){ - byId.setLevel(list.get(i).getLevel()); - } - - } - }else { - if (i!=0&&i!=list.size()-1){ - BigDecimal cumulative = list.get(i - 1).getCumulativeConsumption(); - BigDecimal cumulative1 = list.get(i).getCumulativeConsumption(); - if (cumulative.compareTo(byId.getMoney()) <= 0 && cumulative1.compareTo(byId.getMoney()) >= 0) { - byId.setLevel(list.get(i).getLevel()); - } - } - - } - - } + int appropriateLevel = findAppropriateLevel(list, byId.getMoney()); + byId.setLevel(appropriateLevel); this.updateById(byId); + } + + + private static int findAppropriateLevel(List<MemberLevel> memberLevels, BigDecimal money) { + // 对于最开始的level,设置为0(假设0是最低等级) + int level = 0; + + for (int i = 0; i < memberLevels.size(); i++) { + MemberLevel currentLevel = memberLevels.get(i); + BigDecimal currentCumulativeConsumption = currentLevel.getCumulativeConsumption(); + + // 如果当前成员的消费额小于等于当前等级的累积消费额 + if (money.compareTo(currentCumulativeConsumption) < 0) { + return level; + } + + // 更新level为当前等级,准备下一次比较 + level = currentLevel.getLevel(); + } + + // 如果遍历完成后还没有返回,说明该成员的消费额高于所有已定义等级的累积消费额 + level = memberLevels.get(memberLevels.size() - 1).getLevel(); + return level; } /** @@ -634,6 +628,8 @@ .orderByDesc(Member::getLevel) .list(); } + + } -- Gitblit v1.7.1