From 4eaec4ea2e835cde100deaec0d1059ceec8c0eda Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Mon, 31 May 2021 16:41:53 +0800
Subject: [PATCH] modify

---
 src/main/java/com/xcong/excoin/modules/otc/dao/OtcOrderDao.java                            |    2 +-
 src/main/java/com/xcong/excoin/modules/otc/entity/OtcMarketBussiness.java                  |    4 ++++
 src/main/resources/mapper/otc/OtcEntrustOrderDao.xml                                       |    6 ++++--
 src/main/resources/mapper/otc/OtcOrderDao.xml                                              |    3 +++
 src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java                                 |   24 +++++++++++++++++-------
 src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcMarketBussinessServiceImpl.java |    3 ++-
 6 files changed, 31 insertions(+), 11 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/otc/dao/OtcOrderDao.java b/src/main/java/com/xcong/excoin/modules/otc/dao/OtcOrderDao.java
index ca216ca..99ddf7b 100644
--- a/src/main/java/com/xcong/excoin/modules/otc/dao/OtcOrderDao.java
+++ b/src/main/java/com/xcong/excoin/modules/otc/dao/OtcOrderDao.java
@@ -26,7 +26,7 @@
 
     Integer selectMemberCntForEntrust(@Param("entrustMemberId") Long entrustMemberId);
 
-    Integer selectTotalOrderCount(@Param("entrustMemberId") Long entrustMemberId, @Param("status") Integer status);
+    Integer selectTotalOrderCount(@Param("entrustMemberId") Long entrustMemberId, @Param("status") Integer status, @Param("type") String type);
 
     BigDecimal selectMemberAvgPayTime(@Param("memberId") Long memberId);
 
diff --git a/src/main/java/com/xcong/excoin/modules/otc/entity/OtcMarketBussiness.java b/src/main/java/com/xcong/excoin/modules/otc/entity/OtcMarketBussiness.java
index e77e324..029d111 100644
--- a/src/main/java/com/xcong/excoin/modules/otc/entity/OtcMarketBussiness.java
+++ b/src/main/java/com/xcong/excoin/modules/otc/entity/OtcMarketBussiness.java
@@ -43,4 +43,8 @@
      * 已回款
      */
     private BigDecimal hasBackMoney;
+
+    private Integer saleOrderCnt;
+
+    private BigDecimal saleFinishRatio;
 }
diff --git a/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcMarketBussinessServiceImpl.java b/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcMarketBussinessServiceImpl.java
index 803d3d8..db8ce62 100644
--- a/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcMarketBussinessServiceImpl.java
+++ b/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcMarketBussinessServiceImpl.java
@@ -109,7 +109,8 @@
         }
 
         MarketBussinessInfoVo mbVo = OtcMarketBussinessMapper.INSTANCE.entityToVo(mb);
-
+        mbVo.setTotalOrderCnt(mb.getTotalOrderCnt() + mb.getSaleOrderCnt());
+        mbVo.setFinishRatio(mb.getFinishRatio().add(mb.getSaleFinishRatio()).divide(BigDecimal.valueOf(2), 4, BigDecimal.ROUND_DOWN));
         MemberEntity member = memberDao.selectById(mb.getMemberId());
         OtcEntrustOrder query = new OtcEntrustOrder();
         query.setMemberId(mb.getMemberId());
diff --git a/src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java b/src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java
index 4e336b7..220f934 100644
--- a/src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java
+++ b/src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java
@@ -95,13 +95,22 @@
             for (OtcMarketBussiness mb : list) {
                 // 服务人数
                 Integer buyCnt = otcOrderDao.selectMemberCntForEntrust(mb.getMemberId());
-                // 总单数
-                Integer totalCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), null);
-                // 完成率
-                Integer finishCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), OtcOrder.STATUS_FINISH);
-                if (totalCnt != null && totalCnt != 0) {
-                    BigDecimal finishRatio = BigDecimal.valueOf(finishCnt).divide(BigDecimal.valueOf(totalCnt), 4, BigDecimal.ROUND_DOWN);
+                // 买单数
+                Integer buyTotalCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), null, OtcEntrustOrder.ORDER_TYPE_B);
+                // 买单完成率
+                Integer buyFinishCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), OtcOrder.STATUS_FINISH, OtcEntrustOrder.ORDER_TYPE_B);
+                if (buyTotalCnt != null && buyTotalCnt != 0) {
+                    BigDecimal finishRatio = BigDecimal.valueOf(buyFinishCnt).divide(BigDecimal.valueOf(buyTotalCnt), 4, BigDecimal.ROUND_DOWN);
                     mb.setFinishRatio(finishRatio);
+                }
+
+                // 买单数
+                Integer saleTotalCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), null, OtcEntrustOrder.ORDER_TYPE_S);
+                // 买单完成率
+                Integer saleFinishCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), OtcOrder.STATUS_FINISH, OtcEntrustOrder.ORDER_TYPE_S);
+                if (saleTotalCnt != null && saleTotalCnt != 0) {
+                    BigDecimal finishRatio = BigDecimal.valueOf(saleFinishCnt).divide(BigDecimal.valueOf(saleTotalCnt), 4, BigDecimal.ROUND_DOWN);
+                    mb.setSaleFinishRatio(finishRatio);
                 }
                 // 平均付款时间
                 BigDecimal avgPayTime = otcOrderDao.selectMemberAvgPayTime(mb.getMemberId());
@@ -109,7 +118,8 @@
                 BigDecimal avgCoinTime = otcOrderDao.selectMemberAvgCoinTime(mb.getMemberId());
 
                 mb.setBuyCnt(buyCnt);
-                mb.setTotalOrderCnt(totalCnt);
+                mb.setTotalOrderCnt(buyTotalCnt);
+                mb.setSaleOrderCnt(saleTotalCnt);
                 mb.setAvgPayTime(avgPayTime.intValue());
                 mb.setAvgCoinTime(avgCoinTime.intValue());
 
diff --git a/src/main/resources/mapper/otc/OtcEntrustOrderDao.xml b/src/main/resources/mapper/otc/OtcEntrustOrderDao.xml
index e93f83c..7d64025 100644
--- a/src/main/resources/mapper/otc/OtcEntrustOrderDao.xml
+++ b/src/main/resources/mapper/otc/OtcEntrustOrderDao.xml
@@ -11,8 +11,10 @@
             ,a.remain_coin_amount amount
             ,a.limit_min_amount min
             ,a.limit_max_amount max
-            ,b.total_order_cnt orderCnt
-            ,b.finish_ratio finishRatio
+            ,case when a.order_type = 'B' then b.total_order_cnt
+                  when a.order_type = 'S' then b.sale_order_cnt end orderCnt
+            ,case when a.order_type = 'B' then b.finish_ratio
+                  when a.order_type = 'S' then b.sale_finish_ratio end finishRatio
             ,d.payment_type payType
         from otc_entrust_order a
         left join otc_market_bussiness b on a.member_id=b.member_id
diff --git a/src/main/resources/mapper/otc/OtcOrderDao.xml b/src/main/resources/mapper/otc/OtcOrderDao.xml
index f932ed5..24f8920 100644
--- a/src/main/resources/mapper/otc/OtcOrderDao.xml
+++ b/src/main/resources/mapper/otc/OtcOrderDao.xml
@@ -70,6 +70,9 @@
         <if test="status != null">
             and status = #{status}
         </if>
+        <if test="type != null and type!=''">
+            and order_type = #{type}
+        </if>
     </select>
 
     <select id="selectMemberAvgPayTime" resultType="java.math.BigDecimal">

--
Gitblit v1.9.1