From a7c6abad7c9e59285542156c40081fa54e2df2de Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 20 Dec 2022 17:20:23 +0800
Subject: [PATCH] 20221220 1、每天两点会员星级保证金返还任务 2、每天两点半会员星级更新任务
---
src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java | 119 +++++++++++++++++++++++++++++++++++++--
src/main/java/cc/mrbird/febs/mall/mapper/MallMemberStarBuyMapper.java | 12 ++++
src/main/resources/mapper/modules/MallMemberStarBuyMapper.xml | 29 +++++++++
src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java | 5 +
src/main/java/cc/mrbird/febs/common/enumerates/MallMoneyFlowTypeEnum.java | 1
src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java | 2
6 files changed, 160 insertions(+), 8 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java
index 349537c..34b6f6f 100644
--- a/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java
+++ b/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java
@@ -7,6 +7,11 @@
public enum DataDictionaryEnum {
/**
+ * 保证金返还比例
+ */
+ RETURN_PERCENT("STAR_RETURN","RETURN_PERCENT"),
+
+ /**
* 会员星级市场
* value:升级成为对应的星级需要的价格
* description:升级成为对应的星级名称
diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/MallMoneyFlowTypeEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/MallMoneyFlowTypeEnum.java
index ac39335..3f55d24 100644
--- a/src/main/java/cc/mrbird/febs/common/enumerates/MallMoneyFlowTypeEnum.java
+++ b/src/main/java/cc/mrbird/febs/common/enumerates/MallMoneyFlowTypeEnum.java
@@ -5,6 +5,7 @@
@Getter
public enum MallMoneyFlowTypeEnum {
+ RETURN_MARKET_STAR("星级保证金返还",8),
BUY_MARKET_STAR("购买星级",7),
TEAM_REWARD("团队管理补贴",6),
PAY("支付",5),
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberStarBuyMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberStarBuyMapper.java
index 83e0996..7eefc32 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberStarBuyMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberStarBuyMapper.java
@@ -2,6 +2,18 @@
import cc.mrbird.febs.mall.entity.MallMemberStarBuy;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.math.BigDecimal;
+import java.util.List;
public interface MallMemberStarBuyMapper extends BaseMapper<MallMemberStarBuy> {
+
+ List<MallMemberStarBuy> selectByStatus(@Param("status")int i);
+
+ void updateAvaAmountById(@Param("avaAmount")BigDecimal avaAmount, @Param("id")Long id);
+
+ void updateStatusById(@Param("status")int i, @Param("id")Long id);
+
+ List<MallMemberStarBuy> selectByStatusAndMemberId(@Param("status")int i, @Param("memberId")Long memberId);
}
diff --git a/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java b/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java
index 18f657c..57e3a6b 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java
@@ -1,18 +1,17 @@
package cc.mrbird.febs.mall.quartz;
-import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
-import cc.mrbird.febs.common.enumerates.MemberAccountLevelEnum;
-import cc.mrbird.febs.common.enumerates.MemberAgentLevelEnum;
-import cc.mrbird.febs.common.enumerates.OrderStatusEnum;
-import cc.mrbird.febs.mall.entity.DataDictionaryCustom;
-import cc.mrbird.febs.mall.entity.MallMember;
-import cc.mrbird.febs.mall.entity.MallOrderInfo;
+import cc.mrbird.febs.common.enumerates.*;
+import cc.mrbird.febs.mall.entity.*;
import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
import cc.mrbird.febs.mall.mapper.MallMemberMapper;
+import cc.mrbird.febs.mall.mapper.MallMemberStarBuyMapper;
import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
+import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
+import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.date.DateUnit;
import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.util.ObjectUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import lombok.extern.slf4j.Slf4j;
@@ -20,6 +19,7 @@
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
+import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
@@ -40,6 +40,15 @@
@Autowired
private DataDictionaryCustomMapper dataDictionaryCustomMapper;
+ @Autowired
+ private MallMemberStarBuyMapper mallMemberStarBuyMapper;
+
+ @Autowired
+ private IApiMallMemberWalletService memberWalletService;
+
+ @Autowired
+ private IMallMoneyFlowService mallMoneyFlowService;
+
@Scheduled(cron = "0 0/5 * * * ? ")
public void overtimeJob() {
log.info("订单超时任务执行");
@@ -58,6 +67,102 @@
}
+ @Scheduled(cron = "0 0 2 * * ? ")
+ public void returnBuyStarAmount(){
+ log.info("会员星级保证金返还任务执行");
+ /**
+ * 1、生效中的记录
+ * 2、判断剩余返还金额
+ * 3、生成流水记录
+ * 4、增加用户金额
+ */
+ //生效中记录
+ List<MallMemberStarBuy> mallMemberStarBuys = mallMemberStarBuyMapper.selectByStatus(1);
+ if(CollUtil.isEmpty(mallMemberStarBuys)){
+ return;
+ }
+ for(MallMemberStarBuy mallMemberStarBuy : mallMemberStarBuys){
+ Long memberId = mallMemberStarBuy.getMemberId();
+ MallMember mallMember = mallMemberMapper.selectById(memberId);
+ //用户不存在跳出本次循环
+ if(ObjectUtil.isEmpty(mallMember)){
+ continue;
+ }
+ //返还总金额
+ BigDecimal amount = mallMemberStarBuy.getAmount();
+ //剩余返还总金额不足,跳出本次循环
+ BigDecimal avaAmount = mallMemberStarBuy.getAvaAmount();
+ if(avaAmount.compareTo(BigDecimal.ZERO) <= 0){
+ continue;
+ }
+ //每次返还比例
+ DataDictionaryCustom returnPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ DataDictionaryEnum.RETURN_PERCENT.getType(),
+ DataDictionaryEnum.RETURN_PERCENT.getCode()
+ );
+ String returnPercentStr = returnPercentDic.getValue();
+ BigDecimal returnPercent = new BigDecimal(returnPercentStr).multiply(new BigDecimal(0.01));
+ //本次返还金额
+ BigDecimal returnAmount = amount.multiply(returnPercent);
+ /**
+ * 如果本次返还金额大于剩余返还总金额
+ */
+ if(returnAmount.compareTo(avaAmount) >= 0){
+ returnAmount = avaAmount;
+ avaAmount = BigDecimal.ZERO;
+ }else{
+ avaAmount = avaAmount.subtract(returnAmount).setScale(BigDecimal.ROUND_DOWN,2);
+ }
+ //增加用户金额
+ memberWalletService.addBalance(returnAmount,mallMember.getId());
+ //生成流水记录
+ Long subsidyAmountFlowId = mallMoneyFlowService.addMoneyFlow(
+ mallMember.getId(),
+ mallMemberStarBuy.getBuyCode(),
+ returnAmount,
+ MallMoneyFlowTypeEnum.RETURN_MARKET_STAR.getCode(),
+ MallMoneyFlow.STATUS_SUCCESS,
+ MallMoneyFlow.IS_RETURN_Y,
+ mallMember.getId(),
+ FlowTypeEnum.BALANCE.getValue(),
+ MallMoneyFlowTypeEnum.RETURN_MARKET_STAR.getName()
+ );
+ //更新记录
+ mallMemberStarBuyMapper.updateAvaAmountById(avaAmount,mallMemberStarBuy.getId());
+ }
+ }
+
+ @Scheduled(cron = "0 30 2 * * ? ")
+ public void updateMemberAccountLevelAndBuyStarRecord(){
+ log.info("会员星级更新任务执行");
+ //生效中的记录
+ List<MallMemberStarBuy> mallMemberStarBuys = mallMemberStarBuyMapper.selectByStatus(1);
+ if(CollUtil.isEmpty(mallMemberStarBuys)){
+ return;
+ }
+ for(MallMemberStarBuy mallMemberStarBuy : mallMemberStarBuys){
+ Long memberId = mallMemberStarBuy.getMemberId();
+ MallMember mallMember = mallMemberMapper.selectById(memberId);
+ //用户不存在跳出本次循环
+ if(ObjectUtil.isEmpty(mallMember)){
+ continue;
+ }
+ BigDecimal avaAmount = mallMemberStarBuy.getAvaAmount();
+ /**
+ * 剩余返还总金额等于零,更新为已结束
+ * 判断用户是否还有其他的购买星级的生效记录
+ */
+ if(BigDecimal.ZERO.compareTo(avaAmount) >= 0){
+ mallMemberStarBuyMapper.updateStatusById(2,mallMemberStarBuy.getId());
+ List<MallMemberStarBuy> mallMemberStarBuysIng = mallMemberStarBuyMapper.selectByStatusAndMemberId(1,memberId);
+ //如果没有其他生效中的记录,则更新用户的星级
+ if(CollUtil.isEmpty(mallMemberStarBuysIng)){
+ mallMemberMapper.updateAccountLevelById(MemberAccountLevelEnum.NORMAL.getName(), memberId);
+ }
+ }
+ }
+ }
+
@Scheduled(cron = "0 0 1 * * ? ")
public void updateMemberAgentLevel() {
log.info("会员代理等级升级任务执行");
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index 0817960..a642ecc 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -672,7 +672,7 @@
//产生用户升级会员等级记录
MallMemberStarBuy mallMemberStarBuy = new MallMemberStarBuy();
mallMemberStarBuy.setMemberId(mallMember.getId());
- mallMemberStarBuy.setBuyCode(MallUtils.getLogisticsNum("s"));
+ mallMemberStarBuy.setBuyCode(MallUtils.getLogisticsNum("ms"));
mallMemberStarBuy.setStarName(buyStarDescription);
mallMemberStarBuy.setStarCode(buyStarCode);
mallMemberStarBuy.setAmount(buyStarPriceBigDecimal);
diff --git a/src/main/resources/mapper/modules/MallMemberStarBuyMapper.xml b/src/main/resources/mapper/modules/MallMemberStarBuyMapper.xml
index ec6c6ba..9cfe55b 100644
--- a/src/main/resources/mapper/modules/MallMemberStarBuyMapper.xml
+++ b/src/main/resources/mapper/modules/MallMemberStarBuyMapper.xml
@@ -2,4 +2,33 @@
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cc.mrbird.febs.mall.mapper.MallMemberStarBuyMapper">
+ <select id="selectByStatus" resultType="cc.mrbird.febs.mall.entity.MallMemberStarBuy">
+ select *
+ from mall_member_star_buy
+ where status = #{status}
+ </select>
+
+ <update id="updateAvaAmountById">
+ update mall_member_star_buy
+ set
+ ava_amount = #{avaAmount}
+ where
+ id = #{id}
+ </update>
+
+ <update id="updateStatusById">
+ update mall_member_star_buy
+ set
+ status = #{status}
+ where
+ id = #{id}
+ </update>
+
+ <select id="selectByStatusAndMemberId" resultType="cc.mrbird.febs.mall.entity.MallMemberStarBuy">
+ select *
+ from mall_member_star_buy
+ where status = #{status}
+ and member_id = #{memberId}
+ </select>
+
</mapper>
\ No newline at end of file
--
Gitblit v1.9.1