From 0227f0e8daf1b021e3aed7bceb1895e04cb3bedc Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 05 Jun 2024 15:20:30 +0800
Subject: [PATCH] 1
---
src/main/java/com/nq/service/impl/EchoServices.java | 82 +++++++++++++++++++++--------------------
1 files changed, 42 insertions(+), 40 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/EchoServices.java b/src/main/java/com/nq/service/impl/EchoServices.java
index 29e0f66..8ef961d 100644
--- a/src/main/java/com/nq/service/impl/EchoServices.java
+++ b/src/main/java/com/nq/service/impl/EchoServices.java
@@ -98,52 +98,54 @@
@Override
public void sendMoney() {
- QueryWrapper<OrderEchoBean> queryWrapper = new QueryWrapper<>();
- queryWrapper.eq("state", 1);
- queryWrapper.lt("end_time", System.currentTimeMillis());
- List<OrderEchoBean> list = orderEchoMapper.selectList(queryWrapper);
- log.info("基金定时任务执行数量:{}",list.size());
- for (OrderEchoBean orderEchoBean : list) {
- BigDecimal money = new BigDecimal(orderEchoBean.getMoney()); // 本金
- BigDecimal rate = new BigDecimal(orderEchoBean.getReturnOfRate()); // 收益率
- // 将rate除以100,并向上取整
- rate = rate.divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
+ try {
+ QueryWrapper<OrderEchoBean> queryWrapper = new QueryWrapper<>();
+ queryWrapper.eq("state", 1);
+ queryWrapper.lt("end_time", System.currentTimeMillis());
+ List<OrderEchoBean> list = orderEchoMapper.selectList(queryWrapper);
+ log.info("基金定时任务执行数量:{}", list.size());
+ for (OrderEchoBean orderEchoBean : list) {
+ try {
+ BigDecimal money = new BigDecimal(orderEchoBean.getMoney()); // 本金
+ BigDecimal rate = new BigDecimal(orderEchoBean.getReturnOfRate()); // 收益率
+ // 将rate除以100,并向上取整
+ rate = rate.divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
- // 本金*收益率*周期/365=收益金额
- BigDecimal incomeAmount = money.multiply(rate);
- BigDecimal aml = incomeAmount.add(money);
- UserAssets userAssets = userAssetsMapper.selectOne(new LambdaQueryWrapper<UserAssets>()
- .eq(UserAssets::getUserId, orderEchoBean.getUserId())
- .eq(UserAssets::getAccectType, "IN")
- );
- if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
- continue;
- }
- BigDecimal subtract = aml.subtract(userAssets.getAmountToBeCovered());
- if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
- if(subtract.compareTo(BigDecimal.ZERO) > 0){
- userAssets.setAmountToBeCovered(BigDecimal.ZERO);
- userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(subtract));
- }else{
- userAssets.setAmountToBeCovered(subtract.negate());
+ // 本金*收益率*周期/365=收益金额
+ BigDecimal incomeAmount = money.multiply(rate);
+ BigDecimal aml = incomeAmount.add(money);
+ UserAssets userAssets = userAssetsMapper.selectOne(new LambdaQueryWrapper<UserAssets>()
+ .eq(UserAssets::getUserId, orderEchoBean.getUserId())
+ .eq(UserAssets::getAccectType, "IN")
+ );
+ if (userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0) {
+ continue;
+ }
+ BigDecimal subtract = aml.subtract(userAssets.getAmountToBeCovered());
+ if (userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0) {
+ if (subtract.compareTo(BigDecimal.ZERO) > 0) {
+ userAssets.setAmountToBeCovered(BigDecimal.ZERO);
+ userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(subtract));
+ } else {
+ userAssets.setAmountToBeCovered(subtract.negate());
+ }
+ } else {
+ userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(aml));
+ }
+ userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(money));
+ userAssetsMapper.updateById(userAssets);
+ orderEchoBean.setState("2");
+ orderEchoBean.setEarnings(incomeAmount.toString());
+ orderEchoMapper.updateById(orderEchoBean);
+ } catch (Exception e) {
+ log.error("基金定时任务---失败: " + orderEchoBean.getId(), e);
}
- }else{
- userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(aml));
}
- userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(money));
- userAssetsMapper.updateById(userAssets);
- orderEchoBean.setState("2");
- orderEchoBean.setEarnings(incomeAmount.toString());
- orderEchoMapper.updateById(orderEchoBean);
+ } catch (Exception ex) {
+ log.error("基金定时任务---失败: ", ex);
}
-
}
- public static void main(String[] args) {
- BigDecimal a = new BigDecimal("20");
- BigDecimal b = new BigDecimal("-100");
- System.out.println(a.add(b));
- }
@Override
public int insertEcho(EChoBean eChoBean) {
--
Gitblit v1.9.3