From 61cfa0d30461a8020f4e54330ea049ac6efb07c9 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期三, 17 七月 2024 16:21:41 +0800
Subject: [PATCH] 1、完善代码; 2、修改上行命令结果匹配命令的bug;

---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml |  499 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 487 insertions(+), 12 deletions(-)

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 52dc477..8baa1e8 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeCardOperateMapper.xml
@@ -13,8 +13,9 @@
     <result column="price" jdbcType="FLOAT" property="price" />
     <result column="card_cost" jdbcType="INTEGER" property="cardCost" />
     <result column="gift" jdbcType="FLOAT" property="gift" />
+    <result column="refund_amount" jdbcType="FLOAT" property="refundAmount" />
     <result column="no_trade_amount" jdbcType="FLOAT" property="noTradeAmount" />
-    <result column="operate_type_id" jdbcType="BIGINT" property="operateType" />
+    <result column="operate_type" jdbcType="TINYINT" property="operateType" />
     <result column="payment_id" jdbcType="BIGINT" property="paymentId" />
     <result column="remarks" jdbcType="VARCHAR" property="remarks" />
     <result column="operator" jdbcType="BIGINT" property="operator" />
@@ -23,7 +24,7 @@
   <sql id="Base_Column_List">
     <!--@mbg.generated-->
     id, card_id, client_id, money, system_balance, trade_amount, price, card_cost, gift, 
-    no_trade_amount, operate_type_id, payment_id, remarks, `operator`, operate_dt
+    refund_amount, no_trade_amount, operate_type, payment_id, remarks, `operator`, operate_dt
   </sql>
   <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
     <!--@mbg.generated-->
@@ -42,15 +43,15 @@
     insert into se_card_operate (id, card_id, client_id, 
       money, system_balance, trade_amount, 
       price, card_cost, gift, 
-      no_trade_amount, operate_type, payment_id,
-      remarks, `operator`, operate_dt
-      )
+      refund_amount, no_trade_amount, operate_type, 
+      payment_id, remarks, `operator`, 
+      operate_dt)
     values (#{id,jdbcType=BIGINT}, #{cardId,jdbcType=BIGINT}, #{clientId,jdbcType=BIGINT}, 
       #{money,jdbcType=FLOAT}, #{systemBalance,jdbcType=FLOAT}, #{tradeAmount,jdbcType=FLOAT}, 
       #{price,jdbcType=FLOAT}, #{cardCost,jdbcType=INTEGER}, #{gift,jdbcType=FLOAT}, 
-      #{noTradeAmount,jdbcType=FLOAT}, #{operateType,jdbcType=BIGINT}, #{paymentId,jdbcType=BIGINT},
-      #{remarks,jdbcType=VARCHAR}, #{operator,jdbcType=BIGINT}, #{operateDt,jdbcType=TIMESTAMP}
-      )
+      #{refundAmount,jdbcType=FLOAT}, #{noTradeAmount,jdbcType=FLOAT}, #{operateType,jdbcType=TINYINT}, 
+      #{paymentId,jdbcType=BIGINT}, #{remarks,jdbcType=VARCHAR}, #{operator,jdbcType=BIGINT}, 
+      #{operateDt,jdbcType=TIMESTAMP})
   </insert>
   <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoSe.SeCardOperate">
     <!--@mbg.generated-->
@@ -83,11 +84,14 @@
       <if test="gift != null">
         gift,
       </if>
+      <if test="refundAmount != null">
+        refund_amount,
+      </if>
       <if test="noTradeAmount != null">
         no_trade_amount,
       </if>
       <if test="operateType != null">
-        operate_type_id,
+        operate_type,
       </if>
       <if test="paymentId != null">
         payment_id,
@@ -130,11 +134,14 @@
       <if test="gift != null">
         #{gift,jdbcType=FLOAT},
       </if>
+      <if test="refundAmount != null">
+        #{refundAmount,jdbcType=FLOAT},
+      </if>
       <if test="noTradeAmount != null">
         #{noTradeAmount,jdbcType=FLOAT},
       </if>
       <if test="operateType != null">
-        #{operateType,jdbcType=BIGINT},
+        #{operateType,jdbcType=TINYINT},
       </if>
       <if test="paymentId != null">
         #{paymentId,jdbcType=BIGINT},
@@ -178,11 +185,14 @@
       <if test="gift != null">
         gift = #{gift,jdbcType=FLOAT},
       </if>
+      <if test="refundAmount != null">
+        refund_amount = #{refundAmount,jdbcType=FLOAT},
+      </if>
       <if test="noTradeAmount != null">
         no_trade_amount = #{noTradeAmount,jdbcType=FLOAT},
       </if>
       <if test="operateType != null">
-        operate_type_id = #{operateType,jdbcType=BIGINT},
+        operate_type = #{operateType,jdbcType=TINYINT},
       </if>
       <if test="paymentId != null">
         payment_id = #{paymentId,jdbcType=BIGINT},
@@ -210,12 +220,477 @@
       price = #{price,jdbcType=FLOAT},
       card_cost = #{cardCost,jdbcType=INTEGER},
       gift = #{gift,jdbcType=FLOAT},
+      refund_amount = #{refundAmount,jdbcType=FLOAT},
       no_trade_amount = #{noTradeAmount,jdbcType=FLOAT},
-      operate_type_id = #{operateType,jdbcType=BIGINT},
+      operate_type = #{operateType,jdbcType=TINYINT},
       payment_id = #{paymentId,jdbcType=BIGINT},
       remarks = #{remarks,jdbcType=VARCHAR},
       `operator` = #{operator,jdbcType=BIGINT},
       operate_dt = #{operateDt,jdbcType=TIMESTAMP}
     where id = #{id,jdbcType=BIGINT}
   </update>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鍏呭�艰褰曟暟閲�-->
+  <select id="getRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
+    select
+        COUNT(*) AS recordCount
+    FROM se_card_operate ope
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    INNER JOIN ba_user us ON ope.operator = us.id
+    Left JOIN se_payment_method pay ON ope.payment_id = pay.id
+    <where>
+      AND ope.operate_type in(1, 2, 5)
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "clientNum != null and clientNum > 0">
+        AND cli.clientNum like CONCAT('%',#{clientNum},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+      <!--      <if test = "paymentId != null and paymentId > 0">-->
+      <!--        AND ope.payment_id = ${paymentId}-->
+      <!--      </if>-->
+
+      <!--      <if test = "rechargeTimeStart != null and rechargeTimeStop != null">-->
+      <!--        AND ope.operate_dt BETWEEN #{rechargeTimeStart} AND #{rechargeTimeStop}-->
+      <!--      </if>-->
+    </where>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鍏呭�艰褰�-->
+  <select id="getRecharges" resultType="com.dy.pipIrrGlobal.voSe.VoRecharge">
+    SELECT
+      ope.id AS opeId,
+      card.id AS cardId,
+      cli.name AS clientName,
+      cli.phone,
+      cli.idCard,
+      cli.clientNum,
+      cli.address,
+      card.money,
+      cardNum,
+<!--      CASE-->
+<!--        WHEN card.cardNum LIKE '10%' THEN CONCAT(SUBSTRING(card.cardNum, 7, 6),SUBSTRING(card.cardNum, 14, 4))-->
+<!--        ELSE card.cardNum-->
+<!--      END AS cardNum,-->
+      IFNULL(ope.card_cost,0) AS cardCost,
+      IFNULL(ope.trade_amount, 0) AS amount,
+      IFNULL(ope.refund_amount, 0) AS refundAmount,
+      (IFNULL(ope.money, 0) + IFNULL(ope.trade_amount, 0)) AS afterRecharge,
+      pay.name AS paymentName,
+      ope.price,
+      us.name AS opr,
+      (CASE
+        WHEN ope.operate_type = 1 THEN "寮�鍗�"
+        WHEN ope.operate_type = 2 THEN "鍏呭��"
+        WHEN ope.operate_type = 5 THEN "杩旇繕"
+      END) AS operateType,
+      ope.operate_dt
+    FROM se_card_operate ope
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    INNER JOIN ba_user us ON ope.operator = us.id
+    Left JOIN se_payment_method pay ON ope.payment_id = pay.id
+    <where>
+      AND ope.operate_type in(1, 2, 5)
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "clientNum != null and clientNum > 0">
+        AND cli.clientNum like CONCAT('%',#{clientNum},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+<!--      <if test = "paymentId != null and paymentId > 0">-->
+<!--        AND ope.payment_id = ${paymentId}-->
+<!--      </if>-->
+
+<!--      <if test = "rechargeTimeStart != null and rechargeTimeStop != null">-->
+<!--        AND ope.operate_dt BETWEEN #{rechargeTimeStart} AND #{rechargeTimeStop}-->
+<!--      </if>-->
+    </where>
+    ORDER BY ope.operate_dt DESC
+    <trim prefix="limit " >
+      <if test="start != null and count != null">
+        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+      </if>
+    </trim>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇浜ゆ槗璁板綍鏁�-->
+  <select id="getTransactionRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
+    SELECT
+        COUNT(*) AS recordCount
+    FROM v_trade_details
+    <where>
+      <if test = "villageId != null and villageId > 0">
+        AND villageId = ${villageId}
+      </if>
+
+      <if test = "operateTimeStart != null and operateTimeStop != null">
+        AND tradeTime BETWEEN #{operateTimeStart} AND #{operateTimeStop}
+      </if>
+
+      <if test = "cashierId != null and cashierId > 0">
+        AND cashierId = ${cashierId}
+      </if>
+
+      <if test = "tradeTime != null">
+        AND tradeTime = #{tradeTime}
+      </if>
+    </where>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇浜ゆ槗璁板綍-->
+  <select id="getTransactions" resultType="com.dy.pipIrrGlobal.voSe.VoTradeDetails">
+    SELECT * FROM v_trade_details
+    <where>
+      <if test = "villageId != null and villageId > 0">
+        AND villageId = ${villageId}
+      </if>
+
+      <if test = "operateTimeStart != null and operateTimeStop != null">
+        AND tradeTime BETWEEN #{operateTimeStart} AND #{operateTimeStop}
+      </if>
+
+      <if test = "cashierId != null and cashierId > 0">
+        AND cashierId = ${cashierId}
+      </if>
+    </where>
+    ORDER BY tradeTime
+    <if test="pageCurr != null and pageSize != null">
+      LIMIT ${pageCurr}, ${pageSize}
+    </if>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇寮�鍗¤褰曟暟閲�-->
+  <select id="getActiveCardRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
+    select
+    COUNT(*) AS recordCount
+    FROM se_card_operate ope
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    <where>
+      AND ope.operate_type = 1
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+      <if test = "state != null and state > 0">
+        AND card.state = ${state}
+      </if>
+
+      <if test = "activeTimeStart != null and activeTimeStop != null">
+        AND ope.operate_dt BETWEEN #{activeTimeStart} AND #{activeTimeStop}
+      </if>
+    </where>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇寮�鍗¤褰�-->
+  <select id="getActiveCards" resultType="com.dy.pipIrrGlobal.voSe.VoActiveCard">
+    SELECT
+    CAST(ope.id AS char) AS id ,
+    cli.name AS clientName,
+    cli.clientNum AS clientNum,
+    card.cardNum AS cardNum,
+    card.state AS state,
+    (CASE
+    WHEN card.state = 1 THEN "姝e父"
+    WHEN card.state = 2 THEN "宸叉敞閿�"
+    WHEN card.state = 3 THEN "宸叉寕澶�"
+    END) AS stateName,
+    ope.card_cost AS cardCost,
+    ope.payment_id AS paymentId,
+    (SELECT `name` FROM ba_user WHERE id =  ope.operator) AS operator,
+    ope.operate_dt AS operateDt
+    FROM se_card_operate ope
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    <where>
+      AND ope.operate_type = 1
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+      <if test = "state != null and state > 0">
+        AND card.state = ${state}
+      </if>
+
+      <if test = "activeTimeStart != null and activeTimeStop != null">
+        AND ope.operate_dt BETWEEN #{activeTimeStart} AND #{activeTimeStop}
+      </if>
+    </where>
+    ORDER BY ope.operate_dt DESC
+    <trim prefix="limit " >
+      <if test="start != null and count != null">
+        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+      </if>
+    </trim>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇琛ュ崱璁板綍鏁伴噺-->
+  <select id="getReissueCardRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
+    select
+    COUNT(*) AS recordCount
+    FROM se_card_operate ope
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    <where>
+      AND ope.operate_type = 4
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+      <if test = "activeTimeStart != null and activeTimeStop != null">
+        AND ope.operate_dt BETWEEN #{reissueCardTimeStart} AND #{reissueCardTimeStop}
+      </if>
+    </where>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇琛ュ崱璁板綍-->
+  <select id="getReissueCards" resultType="com.dy.pipIrrGlobal.voSe.VoReissueCard">
+    SELECT
+    CAST(ope.id AS char) AS id ,
+    cli.name AS clientName,
+    cli.clientNum AS clientNum,
+    card.cardNum AS cardNum,
+    ope.card_cost AS cardCost,
+    IFNULL(ope.no_trade_amount,0) AS reissueAmount,
+    (SELECT `name` FROM ba_user WHERE id =  ope.operator) AS operator,
+    ope.operate_dt AS operateDt
+    FROM se_card_operate ope
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    <where>
+      AND ope.operate_type = 4
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+      <if test = "activeTimeStart != null and activeTimeStop != null">
+        AND ope.operate_dt BETWEEN #{reissueCardTimeStart} AND #{reissueCardTimeStop}
+      </if>
+    </where>
+    ORDER BY ope.operate_dt DESC
+    <trim prefix="limit " >
+      <if test="start != null and count != null">
+        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+      </if>
+    </trim>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇閫氱敤鎿嶄綔璁板綍鏁伴噺-->
+  <select id="getCommonOperationRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
+    select
+        COUNT(*) AS recordCount
+    FROM se_card_operate ope
+        INNER JOIN se_client cli ON ope.client_id = cli.id
+        INNER JOIN se_client_card card ON ope.card_id = card.id
+        INNER JOIN ba_user us ON ope.operator = us.id
+    <where>
+      <if test = "operateType != null and operateType > 0">
+        AND ope.operate_type = ${operateType}
+      </if>
+
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+      <if test = "timeStart != null and timeStop != null">
+        AND ope.operate_dt BETWEEN #{timeStart} AND #{timeStop}
+      </if>
+    </where>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇閫氱敤鎿嶄綔璁板綍-->
+  <select id="getCommonOperations" resultType="com.dy.pipIrrGlobal.voSe.VoOperate">
+    SELECT
+        cli.name AS clientName,
+        cli.clientNum,
+        CAST(card.cardNum AS char) AS cardNum,
+        us.name AS operator,
+        ope.operate_dt AS operateDt,
+        IFNULL(ope.trade_amount,0) AS refund,
+        (CASE
+            WHEN ope.payment_id = 1 THEN "鐜伴噾"
+        END) AS refundTypeName,
+        card.money,
+        IFNULL(ope.system_balance,0) AS systemBalance
+    FROM se_card_operate ope
+        INNER JOIN se_client cli ON ope.client_id = cli.id
+        INNER JOIN se_client_card card ON ope.card_id = card.id
+        INNER JOIN ba_user us ON ope.operator = us.id
+    <where>
+      <if test = "operateType != null and operateType > 0">
+        AND ope.operate_type = ${operateType}
+      </if>
+
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "cardNum != null and cardNum !=''">
+        AND card.cardNum like CONCAT('%',#{cardNum},'%')
+      </if>
+
+      <if test = "timeStart != null and timeStop != null">
+        AND ope.operate_dt BETWEEN #{timeStart} AND #{timeStop}
+      </if>
+    </where>
+    ORDER BY ope.operate_dt DESC
+    <trim prefix="limit " >
+      <if test="start != null and count != null">
+        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+      </if>
+    </trim>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鏀舵嵁鍒楄〃鏁�-->
+  <select id="getReceiptsRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
+    SELECT
+    COUNT(*) AS recordCount
+    FROM se_card_operate ope
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_payment_method pay ON ope.payment_id = pay.id
+    INNER JOIN ba_user us ON ope.operator = us.id
+    INNER JOIN ba_district vil ON cli.villageId = vil.id
+    INNER JOIN ba_district tow ON cli.townId = tow.id
+    <where>
+      AND ope.operate_type IN(1,2)
+      <if test = "operateId != null and operateId > 0">
+        AND ope.id = ${operateId}
+      </if>
+
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "timeStart != null and timeStop != null">
+        AND ope.operate_dt BETWEEN #{timeStart} AND #{timeStop}
+      </if>
+    </where>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鏀舵嵁鍒楄〃-->
+  <select id="getReceipts" resultType="com.dy.pipIrrGlobal.voSe.VoReceipt">
+    SELECT
+    CAST(ope.id AS char) AS orderNumber,
+    tow.name AS townName,
+    vil.name AS villageName,
+    cli.`name`,
+    cli.phone,
+    CAST(cli.clientNum AS char) AS clientNum,
+    CAST(card.cardNum AS char) AS cardNum,
+    (CASE
+    WHEN ope.operate_type = 1 THEN '寮�鍗�'
+    WHEN ope.operate_type = 2 THEN '鍏呭��'
+    END) AS operateType,
+    IFNULL(ope.trade_amount,0) AS waterCost,
+    IFNULL(ope.card_cost,0) AS cardCost,
+    (IFNULL(ope.trade_amount,0) + IFNULL(ope.card_cost,0)) AS amount,
+    card.money,
+    pay.`name` AS paymentName,
+    us.`name` AS operatorName,
+    ope.operate_dt AS operateTime,
+    NOW() AS currentTime
+    FROM se_card_operate ope
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_payment_method pay ON ope.payment_id = pay.id
+    INNER JOIN ba_user us ON ope.operator = us.id
+    INNER JOIN ba_district vil ON cli.villageId = vil.id
+    INNER JOIN ba_district tow ON cli.townId = tow.id
+    <where>
+      AND ope.operate_type IN(1,2)
+      <if test = "operateId != null and operateId > 0">
+        AND ope.id = ${operateId}
+      </if>
+
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "timeStart != null and timeStop != null">
+        AND ope.operate_dt BETWEEN #{timeStart} AND #{timeStop}
+      </if>
+    </where>
+    ORDER BY ope.operate_dt DESC
+    <trim prefix="limit " >
+      <if test="start != null and count != null">
+        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+      </if>
+    </trim>
+  </select>
+
+  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鏀舵嵁鏀惰垂閲戦鍚堣-->
+  <select id="getTotalAmount" parameterType="java.util.Map" resultType="java.lang.Double">
+    SELECT
+    SUM(IFNULL(ope.trade_amount,0) + IFNULL(ope.card_cost,0)) AS totalAmount
+    FROM se_card_operate ope
+    INNER JOIN se_client cli ON ope.client_id = cli.id
+    INNER JOIN se_client_card card ON ope.card_id = card.id
+    INNER JOIN se_payment_method pay ON ope.payment_id = pay.id
+    INNER JOIN ba_user us ON ope.operator = us.id
+    INNER JOIN ba_district vil ON cli.villageId = vil.id
+    INNER JOIN ba_district tow ON cli.townId = tow.id
+    <where>
+      AND ope.operate_type IN(1,2)
+      <if test = "operateId != null and operateId > 0">
+        AND ope.id = ${operateId}
+      </if>
+
+      <if test = "clientName != null and clientName !=''">
+        AND cli.name like CONCAT('%',#{clientName},'%')
+      </if>
+
+      <if test = "timeStart != null and timeStop != null">
+        AND ope.operate_dt BETWEEN #{timeStart} AND #{timeStop}
+      </if>
+    </where>
+  </select>
+
+  <!--鏍规嵁姘村崱缂栧彿鑾峰彇鍏舵寕澶辨椂閫�娆鹃噾棰濓紙琛ュ崱鏃跺垽鏂娇鐢級-->
+  <select id="getTradeAmountByCardNo" resultType="java.lang.Double">
+    SELECT
+    ope.trade_amount AS tradeAmount
+    FROM se_client_card card
+    INNER JOIN se_card_operate ope ON ope.card_id = card.id
+    <where>
+      AND ope.operate_type = 6
+      AND card.cardNum = #{cardNum}
+    </where>
+    ORDER BY ope.operate_dt DESC
+    LIMIT 0,1
+  </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0