From 03df72155ccd47912384b3e5f3fceb7331e377de Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期五, 13 九月 2024 14:48:49 +0800
Subject: [PATCH] 2024-09-13 朱宝民 优化获取交易明细记录,余额改为操作表余额,返回字段增加收银员姓名及分页参数

---
 pipIrr-platform/pipIrr-global/src/main/resources/application-database-pj.yml                                |    1 
 pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voSe/VoTradeDetails.java                    |    8 +++
 pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateSv.java   |   11 ++---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml                             |   60 +++++++++++++++++++++++++----
 pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateCtrl.java |    6 +-
 pipIrr-platform/pipIrr-global/src/main/resources/application-global.yml                                     |    2 
 6 files changed, 67 insertions(+), 21 deletions(-)

diff --git a/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voSe/VoTradeDetails.java b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voSe/VoTradeDetails.java
index 2638fb8..d65d5c7 100644
--- a/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voSe/VoTradeDetails.java
+++ b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voSe/VoTradeDetails.java
@@ -22,7 +22,7 @@
  */
 
 @Data
-@JsonPropertyOrder({"orderNumber", "clientName", "cardNum", "idCard", "clientNum", "phone", "operateType", "tradeAmount", "waterCost", "cardCost", "gift", "refundAmount", "money", "paymentName", "tradeTime", "cashierId", "cardState", "districtTitle", "villageId"})
+@JsonPropertyOrder({"orderNumber", "clientName", "cardNum", "idCard", "clientNum", "phone", "operateType", "tradeAmount", "waterCost", "cardCost", "gift", "refundAmount", "money", "paymentName", "tradeTime", "cashierId", "cashierName", "cardState", "districtTitle", "villageId"})
 @HeadRowHeight(30)
 @ContentRowHeight(20)
 public class VoTradeDetails implements BaseEntity {
@@ -140,6 +140,12 @@
     private Long cashierId;
 
     /**
+     * 鏀堕摱鍛樺鍚�
+     */
+    @ColumnWidth(15)
+    private String cashierName;
+
+    /**
      * 鍗$墖鐘舵��
      */
     @ColumnWidth(15)
diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/application-database-pj.yml b/pipIrr-platform/pipIrr-global/src/main/resources/application-database-pj.yml
index 4b385ce..7eb4d18 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/application-database-pj.yml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/application-database-pj.yml
@@ -7,7 +7,6 @@
             driverClassName: com.mysql.cj.jdbc.Driver
 #            url: jdbc:mysql://192.168.40.166:3306/pipIrr_pj?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&useSSL=false&serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull
 #            url: jdbc:mysql://8.130.130.233:3306/pipIrr_pj?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&useSSL=false&serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull
-            #url: jdbc:mysql://8.140.179.55:3306/pipIrr_pj?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&useSSL=false&serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull
             url: jdbc:mysql://127.0.0.1:3306/pipIrr_pj?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&useSSL=false&serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull
             username: root
             password: dysql,;.abc!@#
diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/application-global.yml b/pipIrr-platform/pipIrr-global/src/main/resources/application-global.yml
index 618597e..54ca603 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/application-global.yml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/application-global.yml
@@ -71,7 +71,7 @@
 
 pipIrr:
     global:
-        dev: false   #鏄惁寮�鍙戦樁娈碉紝true鎴杅alse
+        dev: false  #鏄惁寮�鍙戦樁娈碉紝true鎴杅alse
         dsName: ym  #寮�鍙戦樁娈碉紝璁剧疆涓存椂鐨勬暟鎹簱鍚嶇О
     mw:
         webPort: 8070
diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml
index d413173..0d22785 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml
@@ -331,39 +331,81 @@
   <select id="getTransactionRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
     SELECT
         COUNT(*) AS recordCount
-    FROM v_trade_details
+    FROM se_card_operate ope
+        INNER JOIN se_client cli ON ope.client_id = cli.id
+        INNER JOIN se_client_card card ON card.id = ope.card_id
+        LEFT JOIN se_payment_method pay ON ope.payment_id = pay.id
+        INNER JOIN ba_user us ON ope.operator = us.id
     <where>
+      AND ope.operate_type IN(1,2,3,5)
+
       <if test = "villageId != null and villageId > 0">
-        AND villageId = #{villageId}
+        AND cli.villageId = #{villageId}
       </if>
 
       <if test = "operateTimeStart != null and operateTimeStop != null">
-        AND tradeTime BETWEEN #{operateTimeStart} AND #{operateTimeStop}
+        AND ope.operate_dt BETWEEN #{operateTimeStart} AND #{operateTimeStop}
       </if>
 
       <if test = "cashierId != null and cashierId > 0">
-        AND cashierId = #{cashierId}
+        AND us.id = #{cashierId}
       </if>
     </where>
   </select>
 
   <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇浜ゆ槗璁板綍-->
   <select id="getTransactions" resultType="com.dy.pipIrrGlobal.voSe.VoTradeDetails">
-    SELECT * FROM v_trade_details
+    SELECT
+        ope.id AS orderNumber,
+        cli.name AS clientName,
+        card.cardNum AS cardNum,
+        cli.idCard,
+        cli.clientNum,
+        cli.phone,
+        (CASE ope.operate_type
+            WHEN 1 THEN '寮�鍗�'
+            WHEN 2 THEN '鍏呭��'
+            WHEN 3 THEN '閿�鍗�'
+            WHEN 5 THEN '琛ユ墸'
+        END) AS operateType,
+        (IFNULL(ope.trade_amount,0.00) + IFNULL(ope.card_cost,0.00)) AS tradeAmount,
+        IFNULL(ope.trade_amount,0.00) AS waterCost,
+        IFNULL(ope.card_cost,0.00) AS cardCost,
+        IFNULL(ope.gift,0.00) AS gift,
+        IFNULL(ope.refund_amount,0.00) AS refundAmount,
+        ope.money,
+        pay.name AS paymentName,
+        ope.operate_dt as tradeTime,
+        us.id AS cashierId,
+        us.name AS cashierName,
+        (CASE card.state
+            WHEN 1 THEN '姝e父'
+            WHEN 2 THEN '宸叉敞閿�'
+            WHEN 3 THEN '宸叉寕澶�'
+        END) AS cardState,
+        cli.districtTitle,
+        cli.villageId AS villageId
+    FROM se_card_operate ope
+        INNER JOIN se_client cli ON ope.client_id = cli.id
+        INNER JOIN se_client_card card ON card.id = ope.card_id
+        LEFT JOIN se_payment_method pay ON ope.payment_id = pay.id
+        INNER JOIN ba_user us ON ope.operator = us.id
     <where>
+      AND ope.operate_type IN(1,2,3,5)
+
       <if test = "villageId != null and villageId > 0">
-        AND villageId = #{villageId}
+        AND cli.villageId = #{villageId}
       </if>
 
       <if test = "operateTimeStart != null and operateTimeStop != null">
-        AND tradeTime BETWEEN #{operateTimeStart} AND #{operateTimeStop}
+        AND ope.operate_dt BETWEEN #{operateTimeStart} AND #{operateTimeStop}
       </if>
 
       <if test = "cashierId != null and cashierId > 0">
-        AND cashierId = #{cashierId}
+        AND us.id = #{cashierId}
       </if>
     </where>
-    ORDER BY tradeTime
+    ORDER BY ope.operate_dt
     <trim prefix="limit ">
       <if test="start != null and count != null">
         #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateCtrl.java b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateCtrl.java
index 0b577e7..c3638e5 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateCtrl.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateCtrl.java
@@ -156,7 +156,7 @@
         }
 
         /**
-         * 娣诲姞寮�鍗¤褰曪紝閫�杩橀噾棰濅綔涓哄厖鍊奸噾棰�
+         * 娣诲姞寮�鍗℃搷浣滆褰曪紝閫�杩橀噾棰濅綔涓哄厖鍊奸噾棰�
          */
         SeCardOperate seCardOperate = new SeCardOperate();
         seCardOperate.setCardId(cardId);
@@ -400,7 +400,7 @@
         }
 
         /**
-         * 娣诲姞娉ㄩ攢璁板綍
+         * 娣诲姞娉ㄩ攢鎿嶄綔璁板綍
          * 鏀粯鏂瑰紡涓虹幇閲�
          */
         SeCardOperate seCardOperate = new SeCardOperate();
@@ -672,7 +672,7 @@
         }
 
         /**
-         * 娣诲姞琛ユ墸璁板綍
+         * 娣诲姞琛ユ墸鎿嶄綔璁板綍
          */
         SeCardOperate seCardOperate = new SeCardOperate();
         seCardOperate.setCardId(cardId);
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateSv.java
index 2fabd7b..86bd4d3 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateSv.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/cardOperate/CardOperateSv.java
@@ -220,7 +220,7 @@
         }
 
         /**
-         * 娣诲姞姘村崱鎿嶄綔璁板綍
+         * 娣诲姞姘村崱鍏呭�兼搷浣滆褰�
          */
         SeCardOperate seCardOperate = new SeCardOperate();
         seCardOperate.setCardId(cardId);
@@ -330,12 +330,13 @@
         // 鑾峰彇绗﹀悎鏉′欢鐨勮褰曟暟
         Long itemTotal = Optional.ofNullable(seCardOperateMapper.getTransactionRecordCount(params)).orElse(0L);
 
-        QueryResultVo rsVo = new QueryResultVo<>() ;
+        QueryResultVo<List<VoTradeDetails>> rsVo = new QueryResultVo<>() ;
         rsVo.pageSize = vo.pageSize ;
         rsVo.pageCurr = vo.pageCurr ;
         rsVo.calculateAndSet(itemTotal, params);
 
-        List<VoTradeDetails> list = seCardOperateMapper.getTransactions(params);
+        rsVo.obj = seCardOperateMapper.getTransactions(params);
+        List<VoTradeDetails> list = rsVo.obj;
         if(list.size() == 0) {
             return new HashMap();
         }
@@ -361,15 +362,13 @@
         }
 
         Map map_record = new HashMap();
-        map_record.put("itemTotal", itemTotal);
-        map_record.put("list", list);
+        map_record.put("list", rsVo);
 
         Map map_result = new HashMap();
         map_result.put("waterCost", df.format(totalWaterCost));
         map_result.put("cardCost", df.format(totalCardCost));
         map_result.put("gift", df.format(totalGift));
         map_result.put("refund", df.format(totalRefund));
-
 
         map_result.put("records", map_record);
 

--
Gitblit v1.8.0