From 8b8dabe9413ff53593eec4484e013240c1b9a530 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 03 Aug 2022 15:48:07 +0800
Subject: [PATCH] 20220803 积分池
---
src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java | 2 +
src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java | 7 +++
src/test/java/cc/mrbird/febs/ProfitTest.java | 5 ++
src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java | 47 +++++++++++++++++++++++
src/main/java/cc/mrbird/febs/mall/quartz/ProfitJob.java | 8 ++++
src/main/resources/mapper/modules/MallOrderInfoMapper.xml | 5 ++
src/main/java/cc/mrbird/febs/mall/service/IMemberProfitService.java | 2 +
7 files changed, 75 insertions(+), 1 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java
index 7af4142..9268dd7 100644
--- a/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java
+++ b/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java
@@ -88,7 +88,12 @@
/**
* 抽奖
*/
- PRIZE(17);
+ PRIZE(17),
+
+ /**
+ * 抽奖
+ */
+ SCORE_POOL(18);
private final int value;
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java
index f511408..ee0901c 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java
@@ -61,4 +61,6 @@
List<MallOrderInfo> selectOrderInfoWithNormalGoods(@Param("date") Date date);
BigDecimal selectSumAmountByPayMethodAndStatue(@Param("payMethod")String name, @Param("statue")int value);
+
+ BigDecimal selectTotalAmountByPayDoneAndDataString(@Param("payResult")int i, @Param("date") Date date);
}
diff --git a/src/main/java/cc/mrbird/febs/mall/quartz/ProfitJob.java b/src/main/java/cc/mrbird/febs/mall/quartz/ProfitJob.java
index be03796..33ffb60 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/ProfitJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/ProfitJob.java
@@ -74,4 +74,12 @@
public void rankJob() {
memberProfitService.rankProfit();
}
+
+ /**
+ * 积分池,所有消费拿出10%放到积分池,然后按1%每天释放加权平分
+ */
+ @Scheduled(cron = "0 0 2 * * ?")
+ public void scorePool() {
+ memberProfitService.scorePool();
+ }
}
diff --git a/src/main/java/cc/mrbird/febs/mall/service/IMemberProfitService.java b/src/main/java/cc/mrbird/febs/mall/service/IMemberProfitService.java
index 2d7a643..abb14d5 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/IMemberProfitService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/IMemberProfitService.java
@@ -39,4 +39,6 @@
* 店补/董事
*/
void storeAndDirectorProfit(Date profitDate);
+
+ void scorePool();
}
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
index 89dab43..c1ad6f2 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
@@ -5,6 +5,7 @@
import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
import cc.mrbird.febs.common.utils.AppContants;
+import cc.mrbird.febs.common.utils.RedisUtils;
import cc.mrbird.febs.mall.entity.*;
import cc.mrbird.febs.mall.mapper.*;
import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
@@ -13,10 +14,12 @@
import cc.mrbird.febs.mall.service.IMemberProfitService;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.date.DateField;
+import cn.hutool.core.date.DateTime;
import cn.hutool.core.date.DateUnit;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import lombok.RequiredArgsConstructor;
@@ -477,4 +480,48 @@
}
log.info("#####==店补/董事==end==######");
}
+
+ private final RedisUtils redisUtils;
+
+ @Override
+ public void scorePool() {
+ log.info("#####==积分池==start==######");
+ /**
+ * 后一天2点,结算前一天的所有消费
+ * 积分池增加每日消费的10%
+ * 每天释放1%,给全体用户
+ */
+ //前一天的所有消费的10%
+ Date date = DateUtil.offsetDay(new Date(), -1);
+ BigDecimal totalAmount = mallOrderInfoMapper.selectTotalAmountByPayDoneAndDataString(1, date);
+ BigDecimal multiplyTotalAmount = totalAmount.multiply(new BigDecimal(0.1));
+
+ String redisKey = "scorePool";
+ String scorePoolRedis = redisUtils.getString(redisKey);
+ if(StrUtil.isBlank(scorePoolRedis)){
+ redisUtils.set(redisKey,0,0L);
+ }
+
+ BigDecimal scorePoolOld = new BigDecimal(redisUtils.getString(redisKey));
+ BigDecimal scorePoolNew = scorePoolOld.add(multiplyTotalAmount);
+
+ //每天释放1%给全体用户
+ BigDecimal scorePoolToDay = scorePoolNew.multiply(new BigDecimal(0.01));
+
+ redisUtils.set(redisKey,scorePoolNew.subtract(scorePoolToDay).intValue(),0L);
+
+ List<MallMember> mallMembers = mallMemberMapper.selectList(new QueryWrapper<>());
+ if(CollUtil.isNotEmpty(mallMembers)){
+ BigDecimal income = new BigDecimal(scorePoolToDay.divide(new BigDecimal(mallMembers.size()), 2, RoundingMode.HALF_UP).intValue());
+ if(income.compareTo(BigDecimal.ZERO) < 1){
+ return;
+ }
+ for(MallMember mallMember : mallMembers){
+ walletService.add(income, mallMember.getId(), "score");
+ moneyFlowService.addMoneyFlow(mallMember.getId(), income, MoneyFlowTypeEnum.SCORE_POOL.getValue(), null, FlowTypeEnum.SCORE.getValue());
+ }
+ }
+ log.info("#####==积分池==end==######");
+ }
+
}
diff --git a/src/main/resources/mapper/modules/MallOrderInfoMapper.xml b/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
index 660351c..3227883 100644
--- a/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
+++ b/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
@@ -283,4 +283,9 @@
select IFNULL(sum(IFNULL(amount,0)),0) from mall_order_info
where pay_method = #{payMethod} and status = #{statue}
</select>
+
+ <select id="selectTotalAmountByPayDoneAndDataString" resultType="java.math.BigDecimal">
+ select IFNULL(sum(IFNULL(amount,0)),0) from mall_order_info
+ where pay_result = #{payResult} and date_format(pay_time, '%Y-%m-%d') = date_format(#{date}, '%Y-%m-%d')
+ </select>
</mapper>
\ No newline at end of file
diff --git a/src/test/java/cc/mrbird/febs/ProfitTest.java b/src/test/java/cc/mrbird/febs/ProfitTest.java
index 435c997..155bb83 100644
--- a/src/test/java/cc/mrbird/febs/ProfitTest.java
+++ b/src/test/java/cc/mrbird/febs/ProfitTest.java
@@ -92,4 +92,9 @@
public void changeAmount(Map<String, Integer> amount) {
amount.put("amount", 2);
}
+
+ @Test
+ public void scorePool(){
+ memberProfitService.scorePool();
+ }
}
--
Gitblit v1.9.1