From 19c5321559b3f050620719dea61b5f3c6cd4c224 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期四, 12 九月 2024 20:43:00 +0800
Subject: [PATCH] 2024-09-12 朱宝民 完善交易汇总查询接口,完善获取交易明细接口

---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeClientCardMapper.xml | 1137 +++++++++++++++++++++++++++++++++--------------------------
 1 files changed, 629 insertions(+), 508 deletions(-)

diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeClientCardMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeClientCardMapper.xml
index 8a2ea9f..5f2f303 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeClientCardMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/SeClientCardMapper.xml
@@ -1,532 +1,653 @@
 <?xml version="1.0" encoding="UTF-8"?>
 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 <mapper namespace="com.dy.pipIrrGlobal.daoSe.SeClientCardMapper">
-  <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
-    <!--@mbg.generated-->
-    <!--@Table se_client_card-->
-    <id column="id" jdbcType="BIGINT" property="id" />
-    <result column="cardAddr" jdbcType="VARCHAR" property="cardaddr" />
-    <result column="cardNum" jdbcType="BIGINT" property="cardnum" />
-    <result column="clientId" jdbcType="BIGINT" property="clientid" />
-    <result column="money" jdbcType="FLOAT" property="money" />
-    <result column="state" jdbcType="TINYINT" property="state" />
-    <result column="original_card_id" jdbcType="BIGINT" property="originalCardId"/>
-    <result column="createDt" jdbcType="TIMESTAMP" property="createdt" />
-    <result column="replaceDt" jdbcType="TIMESTAMP" property="replacedt" />
-    <result column="rechargeDt" jdbcType="TIMESTAMP" property="rechargedt" />
-    <result column="lossDtDt" jdbcType="TIMESTAMP" property="lossdtdt" />
-    <result column="cancelDt" jdbcType="TIMESTAMP" property="canceldt" />
-    <result column="unlockDt" jdbcType="TIMESTAMP" property="unlockdt" />
-    <result column="reversalDt" jdbcType="TIMESTAMP" property="reversaldt" />
-    <result column="refundDt" jdbcType="TIMESTAMP" property="refunddt" />
-    <result column="consumeDt" jdbcType="TIMESTAMP" property="consumedt" />
-    <result column="lastOper" jdbcType="TINYINT" property="lastoper" />
-    <result column="remarks" jdbcType="VARCHAR" property="remarks" />
-  </resultMap>
-  <sql id="Base_Column_List">
-    <!--@mbg.generated-->
-    id, cardAddr, cardNum, clientId, money, `state`, original_card_id, createDt, replaceDt, rechargeDt,
-    lossDtDt, cancelDt, unlockDt, reversalDt, refundDt, consumeDt, lastOper, remarks
-  </sql>
-  <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
-    <!--@mbg.generated-->
-    select 
-    <include refid="Base_Column_List" />
-    from se_client_card
-    where id = #{id,jdbcType=BIGINT}
-  </select>
-  <delete id="deleteByPrimaryKey" parameterType="java.lang.Long">
-    <!--@mbg.generated-->
-    delete from se_client_card
-    where id = #{id,jdbcType=BIGINT}
-  </delete>
-
-  <!--渚濇嵁姘村崱鍦板潃鑾峰彇姘村崱缂栧彿锛�12鏈�19鏃ュ簾寮冿級-->
-  <select id="getCardIdByAddr" resultType="java.lang.Long">
-    SELECT id AS cardId FROM se_client_card WHERE cardAddr = #{cardAddr}
-  </select>
-
-  <!--鏍规嵁姘村崱缂栧彿鑾峰彇姘村崱琛ㄤ富閿紙12鏈�19鏃ユ坊鍔犲悗搴熷純锛�-->
-  <select id="getCardIdByNum" resultType="java.lang.Long">
-    SELECT id AS cardId FROM se_client_card WHERE cardNum = #{cardNum}
-  </select>
-
-  <!--鏍规嵁姘村崱缂栧彿鑾峰彇姘村崱琛ㄤ富閿強鍐滄埛缂栧彿-->
-  <select id="getCardIdAndClientNum" resultType="java.util.Map">
-<!--    SELECT id AS cardId, clientNum FROM se_client_card WHERE cardNum = #{cardNum}-->
-    SELECT
-        card.id AS cardId,
-        cli.clientNum,
-        cli.id AS clientId
-    FROM se_client_card card
-        INNER JOIN se_client cli ON card.clientId = cli.id
-    WHERE card.cardNum = #{cardNum}
-  </select>
-
-
-  <!--鏍规嵁琛屾斂鍖哄垝涓叉ā绯婃煡璇㈡按鍗$紪鍙�-->
-  <select id="getCardNumOfMax"  resultType="java.lang.String">
-    SELECT cardNum
-    FROM se_client_card
-    WHERE cardNum LIKE CONCAT('%',#{areaCode},'%')
-    ORDER BY cardNum desc
-    LIMIT 0,1
-  </select>
-
-  <insert id="insert" keyColumn="id" keyProperty="id" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
-    <!--@mbg.generated-->
-    insert into se_client_card (id, cardAddr, cardNum, clientId,
-      money, `state`, original_card_id, createDt,
-      replaceDt, rechargeDt, lossDtDt, 
-      cancelDt, unlockDt, reversalDt, refundDt,
-      consumeDt, lastOper, remarks
-      )
-    values (#{id,jdbcType=BIGINT}, #{cardaddr,jdbcType=VARCHAR}, #{cardnum,jdbcType=BIGINT}, #{clientid,jdbcType=BIGINT},
-      #{money,jdbcType=FLOAT}, #{state,jdbcType=TINYINT}, #{originalCardId,jdbcType=BIGINT}, #{createdt,jdbcType=TIMESTAMP},
-      #{replacedt,jdbcType=TIMESTAMP}, #{rechargedt,jdbcType=TIMESTAMP}, #{lossdtdt,jdbcType=TIMESTAMP}, 
-      #{canceldt,jdbcType=TIMESTAMP}, #{unlockdt,jdbcType=TIMESTAMP}, #{reversaldt,jdbcType=TIMESTAMP},
-      #{refunddt,jdbcType=TIMESTAMP}, #{consumedt,jdbcType=TIMESTAMP}, #{lastoper,jdbcType=TINYINT}, #{remarks,jdbcType=VARCHAR}
-      )
-
-  </insert>
-  <insert id="insertSelective" keyColumn="id" keyProperty="id" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard" useGeneratedKeys="true">
-    <!--@mbg.generated-->
-    insert into se_client_card
-    <trim prefix="(" suffix=")" suffixOverrides=",">
-      <if test="cardaddr != null">
+    <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
+        <!--@mbg.generated-->
+        <!--@Table se_client_card-->
+        <id column="id" jdbcType="BIGINT" property="id"/>
+        <result column="protocol" jdbcType="VARCHAR" property="protocol"/>
+        <result column="cardAddr" jdbcType="VARCHAR" property="cardaddr"/>
+        <result column="cardNum" jdbcType="BIGINT" property="cardnum"/>
+        <result column="clientId" jdbcType="BIGINT" property="clientid"/>
+        <result column="money" jdbcType="FLOAT" property="money"/>
+        <result column="state" jdbcType="TINYINT" property="state"/>
+        <result column="original_card_id" jdbcType="BIGINT" property="originalCardId"/>
+        <result column="createDt" jdbcType="TIMESTAMP" property="createdt"/>
+        <result column="replaceDt" jdbcType="TIMESTAMP" property="replacedt"/>
+        <result column="rechargeDt" jdbcType="TIMESTAMP" property="rechargedt"/>
+        <result column="lossDtDt" jdbcType="TIMESTAMP" property="lossdtdt"/>
+        <result column="cancelDt" jdbcType="TIMESTAMP" property="canceldt"/>
+        <result column="unlockDt" jdbcType="TIMESTAMP" property="unlockdt"/>
+        <result column="reversalDt" jdbcType="TIMESTAMP" property="reversaldt"/>
+        <result column="refundDt" jdbcType="TIMESTAMP" property="refunddt"/>
+        <result column="consumeDt" jdbcType="TIMESTAMP" property="consumedt"/>
+        <result column="lastOper" jdbcType="TINYINT" property="lastoper"/>
+        <result column="remarks" jdbcType="VARCHAR" property="remarks"/>
+    </resultMap>
+    <sql id="Base_Column_List">
+        <!--@mbg.generated-->
+        id,
+        protocol,
         cardAddr,
-      </if>
-      <if test="cardnum != null">
         cardNum,
-      </if>
-      <if test="clientid != null">
         clientId,
-      </if>
-      <if test="money != null">
         money,
-      </if>
-      <if test="state != null">
         `state`,
-      </if>
-      <if test="originalCardId != null">
         original_card_id,
-      </if>
-      <if test="createdt != null">
         createDt,
-      </if>
-      <if test="replacedt != null">
         replaceDt,
-      </if>
-      <if test="rechargedt != null">
         rechargeDt,
-      </if>
-      <if test="lossdtdt != null">
         lossDtDt,
-      </if>
-      <if test="canceldt != null">
         cancelDt,
-      </if>
-      <if test="unlockdt != null">
         unlockDt,
-      </if>
-      <if test="reversaldt != null">
         reversalDt,
-      </if>
-      <if test="refunddt != null">
         refundDt,
-      </if>
-      <if test="consumedt != null">
         consumeDt,
-      </if>
-      <if test="lastoper != null">
         lastOper,
-      </if>
-      <if test="remarks != null">
-        remarks,
-      </if>
-    </trim>
-    <trim prefix="values (" suffix=")" suffixOverrides=",">
-      <if test="cardaddr != null">
-        #{cardaddr,jdbcType=VARCHAR},
-      </if>
-      <if test="cardnum != null">
-        #{cardnum,jdbcType=BIGINT},
-      </if>
-      <if test="clientid != null">
-        #{clientid,jdbcType=BIGINT},
-      </if>
-      <if test="money != null">
-        #{money,jdbcType=FLOAT},
-      </if>
-      <if test="state != null">
-        #{state,jdbcType=TINYINT},
-      </if>
-      <if test="originalCardId != null">
-        #{originalCardId,jdbcType=BIGINT},
-      </if>
-      <if test="createdt != null">
-        #{createdt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="replacedt != null">
-        #{replacedt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="rechargedt != null">
-        #{rechargedt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="lossdtdt != null">
-        #{lossdtdt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="canceldt != null">
-        #{canceldt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="unlockdt != null">
-        #{unlockdt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="reversaldt != null">
-        #{reversaldt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="refunddt != null">
-        #{refunddt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="consumedt != null">
-        #{consumedt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="lastoper != null">
-        #{lastoper,jdbcType=TINYINT},
-      </if>
-      <if test="remarks != null">
-        #{remarks,jdbcType=VARCHAR},
-      </if>
-    </trim>
-  </insert>
-  <update id="updateByPrimaryKeySelective" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
-    <!--@mbg.generated-->
-    update se_client_card
-    <set>
-      <if test="cardaddr != null">
-        cardAddr = #{cardaddr,jdbcType=VARCHAR},
-      </if>
-      <if test="cardnum != null">
-        cardNum = #{cardnum,jdbcType=BIGINT},
-      </if>
-      <if test="clientid != null">
-        clientId = #{clientid,jdbcType=BIGINT},
-      </if>
-      <if test="money != null">
-        money = #{money,jdbcType=FLOAT},
-      </if>
-      <if test="state != null">
-        `state` = #{state,jdbcType=TINYINT},
-      </if>
-      <if test="originalCardId != null">
-        `original_card_id` = #{originalCardId,jdbcType=BIGINT},
-      </if>
-      <if test="createdt != null">
-        createDt = #{createdt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="replacedt != null">
-        replaceDt = #{replacedt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="rechargedt != null">
-        rechargeDt = #{rechargedt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="lossdtdt != null">
-        lossDtDt = #{lossdtdt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="canceldt != null">
-        cancelDt = #{canceldt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="unlockdt != null">
-        unlockDt = #{unlockdt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="reversaldt != null">
-        reversalDt = #{reversaldt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="refunddt != null">
-        refundDt = #{refunddt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="consumedt != null">
-        consumeDt = #{consumedt,jdbcType=TIMESTAMP},
-      </if>
-      <if test="lastoper != null">
-        lastOper = #{lastoper,jdbcType=TINYINT},
-      </if>
-      <if test="remarks != null">
-        remarks = #{remarks,jdbcType=VARCHAR},
-      </if>
-    </set>
-    where id = #{id,jdbcType=BIGINT}
-  </update>
-  <update id="updateByPrimaryKey" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
-    <!--@mbg.generated-->
-    update se_client_card
-    set cardAddr = #{cardaddr,jdbcType=VARCHAR},
-      cardNum = #{cardnum,jdbcType=BIGINT},
-      clientId = #{clientid,jdbcType=BIGINT},
-      money = #{money,jdbcType=FLOAT},
-      `state` = #{state,jdbcType=TINYINT},
-      original_card_id = #{originalCardId,jdbcType=BIGINT},
-      createDt = #{createdt,jdbcType=TIMESTAMP},
-      replaceDt = #{replacedt,jdbcType=TIMESTAMP},
-      rechargeDt = #{rechargedt,jdbcType=TIMESTAMP},
-      lossDtDt = #{lossdtdt,jdbcType=TIMESTAMP},
-      cancelDt = #{canceldt,jdbcType=TIMESTAMP},
-      unlockDt = #{unlockdt,jdbcType=TIMESTAMP},
-      reversalDt = #{reversaldt,jdbcType=TIMESTAMP},
-      refundDt = #{refunddt,jdbcType=TIMESTAMP},
-      consumeDt = #{consumedt,jdbcType=TIMESTAMP},
-      lastOper = #{lastoper,jdbcType=TINYINT},
-      remarks = #{remarks,jdbcType=VARCHAR}
-    where id = #{id,jdbcType=BIGINT}
-  </update>
-
-  <!--鏍规嵁鍐滄埛涓婚敭鑾峰彇姘村崱鍒楄〃-->
-  <select id="getCardInfoByClientId" resultType="com.dy.pipIrrGlobal.voSe.VoCardInfo">
-    SELECT
-        cardNum,
-        '鐢ㄦ埛鍗�' AS cardType,
-        money,
-        (CASE
-            WHEN state = 1 THEN "姝e父"
-            WHEN state = 2 THEN "宸叉敞閿�"
-            ELSE "宸叉寕澶�"
-        END) AS state
-    FROM se_client_card
-    WHERE clientId = ${clientId}
-  </select>
-
-  <!--鏍规嵁姘村崱缂栧彿鑾峰彇鎿嶄綔璁板綍鍒楄〃-->
-  <select id="getOperateRecordsByCardNum" resultType="java.util.HashMap">
-    SELECT * FROM v_operate WHERE cardNum = ${cardNum}
-  </select>
-
-  <!--鏍规嵁姘村崱缂栧彿鑾峰彇浣欓-->
-  <select id="getMoneyByCardNum" resultType="java.lang.Float">
-    SELECT money FROM se_client_card WHERE cardNum = ${cardNum}
-  </select>
-
-  <!--鏍规嵁姘村崱缂栧彿鑾峰彇鍏呭�兼�婚-->
-  <select id="sumRechargeByCardNum" resultType="java.lang.Float">
-    SELECT
-      SUM(his.amount) AS amount
-    FROM se_recharge_history his
-        INNER JOIN se_client_card card ON his.cardId = card.id
-    WHERE card.cardNum = ${cardNum}
-  </select>
-
-  <!--鏍规嵁姘村崱缂栧彿鑾峰彇鍗$墖鐘舵�侊細1-寮�鍗★紝2-琛ュ崱锛�3-鍏呭�硷紝4-鎸傚け锛�5-娉ㄩ攢锛�6-瑙i攣锛�7-鍐叉锛�8-娑堣垂-->
-  <select id="getCardStateByCardNum" resultType="java.lang.String">
-<!--    SELECT-->
-<!--      (CASE-->
-<!--         WHEN lastOper = 1 THEN "寮�鍗�"-->
-<!--         WHEN lastOper = 2 THEN "琛ュ崱"-->
-<!--         WHEN lastOper = 3 THEN "鍏呭��"-->
-<!--         WHEN lastOper = 4 THEN "鎸傚け"-->
-<!--         WHEN lastOper = 5 THEN "娉ㄩ攢"-->
-<!--         WHEN lastOper = 6 THEN "瑙i攣"-->
-<!--         WHEN lastOper = 7 THEN "鍐叉"-->
-<!--         WHEN lastOper = 8 THEN "娑堣垂"-->
-<!--        END) AS stateName-->
-<!--    FROM se_client_card-->
-<!--    WHERE cardNum = ${cardNum}-->
-    SELECT
-        (CASE
-            WHEN state = 1 THEN '姝e父'
-            WHEN state = 2 THEN '宸叉敞閿�'
-            WHEN state = 3 THEN '宸叉寕澶�'
-        END) AS stateName
-    FROM se_client_card
-    WHERE cardNum = ${cardNum}
-  </select>
-
-  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇姘村崱鍒楄〃璁板綍鏁帮紝搴旂敤绋嬪簭浣跨敤-->
-  <select id="getCardsCount" parameterType="java.util.Map" resultType="java.lang.Long">
-    SELECT
-        COUNT(*) AS recordCount
-    FROM se_client_card card
-        INNER JOIN se_client cli ON card.clientId = cli.id
-    <where>
-      <if test = "clientNum != null and clientNum !=''">
-        AND cli.clientNum like CONCAT('%',#{clientNum},'%')
-      </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>
-    </where>
-  </select>
-
-  <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇姘村崱鍒楄〃锛屽簲鐢ㄧ▼搴忎娇鐢�-->
-  <select id="getCards" resultType="com.dy.pipIrrGlobal.voSe.VoCards">
-    SELECT
-        cli.clientNum,
-        cli.name AS clientName,
-        card.cardNum,
-        cli.phone,
-        cli.idCard,
-        card.state AS cardState,
-        (CASE
-            WHEN card.state = 1 THEN '姝e父'
-            WHEN card.state = 2 THEN '宸叉敞閿�'
-            WHEN card.state = 3 THEN '宸叉寕澶�'
-        End) AS stateName,
-        '鍐滄埛鍗�' AS cardType,
-        FORMAT(card.money, 2) AS money
-    FROM se_client_card card
-        INNER JOIN se_client cli ON card.clientId = cli.id
-    <where>
-      <if test = "clientNum != null and clientNum !=''">
-        AND cli.clientNum like CONCAT('%',#{clientNum},'%')
-      </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>
-    </where>
-    ORDER BY card.id
-    <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="getUnreplacedRecordCount" resultType="java.lang.Long">
-    SELECT
-        COUNT(*) AS recordCount
-    FROM se_client_card card
-           INNER JOIN se_client cli ON card.clientId = cli.id
-    WHERE card.state = 3 AND NOT EXISTS (SELECT * FROM se_client_card card2 WHERE card2.original_card_id = card.cardNum)
-  </select>
-
-  <!--鑾峰彇宸叉寕澶辨湭琛ュ崱鐨勮褰�-->
-  <select id="getUnreplaced" resultType="com.dy.pipIrrGlobal.voSe.VoCards">
-    SELECT
-        cli.clientNum,
-        cli.name AS clientName,
-        card.cardNum,
-        cli.phone,
-        cli.idCard,
-        card.state AS cardState,
-        (CASE
-            WHEN card.state = 1 THEN '姝e父'
-            WHEN card.state = 2 THEN '宸叉敞閿�'
-            WHEN card.state = 3 THEN '宸叉寕澶�'
-        End) AS stateName,
-        '鍐滄埛鍗�' AS cardType,
-        FORMAT(card.money,2) AS money
-    FROM se_client_card card
-        INNER JOIN se_client cli ON card.clientId = cli.id
-    WHERE card.state = 3 AND NOT EXISTS (SELECT * FROM se_client_card card2 WHERE card2.original_card_id = card.cardNum)
-    ORDER BY card.id
-    <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="isLostAndUnreplaced" resultType="java.lang.Integer">
-    SELECT
-        COUNT(*) AS recordCount
-    FROM se_client_card card
-        INNER JOIN se_client_card card2 ON card2.original_card_id = card.cardNum
-    <where>
-      AND card.state = 3
-      <if test = "cardNum != null and cardNum > 0">
-        AND card.cardNum = #{cardNum}
-      </if>
-    </where>
-  </select>
-  <!--鏍规嵁鍐滄埛濮撳悕鍜屾墜鏈哄彿鑾峰彇姘村崱鍒楄〃璁板綍鏁帮紝搴旂敤绋嬪簭浣跨敤-->
-  <select id="getCardsByClientNameAndPhoneCount" resultType="java.lang.Long">
-    SELECT
-      COUNT(*) AS recordCount
-    FROM se_client_card card
-    INNER JOIN se_client cli ON card.clientId = cli.id
-    <where>
-      card.state = 1
-      <if test = "clientName != null and clientName !=''">
-        AND cli.name like CONCAT('%',#{clientName},'%')
-      </if>
-
-      <if test = "phone != null and phone !=''">
-        AND cli.phone like CONCAT('%',#{phone},'%')
-      </if>
-    </where>
+        remarks
+    </sql>
+    <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
+        <!--@mbg.generated-->
+        select
+        <include refid="Base_Column_List"/>
+        from se_client_card
+        where id = #{id,jdbcType=BIGINT}
     </select>
-  <!--鏍规嵁鍐滄埛濮撳悕鍜屾墜鏈哄彿鑾峰彇姘村崱鍒楄〃锛屽簲鐢ㄧ▼搴忎娇鐢�-->
-  <select id="getCardsByClientNameAndPhone" resultType="com.dy.pipIrrGlobal.voSe.VoCards2">
-    SELECT
-    card.id AS clientCardId,
-    cli.id AS clientId,
-    cli.clientNum,
-    cli.name AS clientName,
-    card.cardNum,
-    cli.phone,
-    cli.idCard,
-    card.state AS cardState,
-    (CASE
-    WHEN card.state = 1 THEN '姝e父'
-    WHEN card.state = 2 THEN '宸叉敞閿�'
-    WHEN card.state = 3 THEN '宸叉寕澶�'
-    End) AS stateName,
-    '鍐滄埛鍗�' AS cardType,
-    FORMAT(card.money, 2) AS money
-    FROM se_client_card card
-    INNER JOIN se_client cli ON card.clientId = cli.id
-    <where>
-      card.state = 1
-      <if test = "clientName != null and clientName !=''">
-        AND cli.name like CONCAT('%',#{clientName},'%')
-      </if>
+    <delete id="deleteByPrimaryKey" parameterType="java.lang.Long">
+        <!--@mbg.generated-->
+        delete
+        from se_client_card
+        where id = #{id,jdbcType=BIGINT}
+    </delete>
 
-      <if test = "phone != null and phone !=''">
-        AND cli.phone like CONCAT('%',#{phone},'%')
-      </if>
-    </where>
-    ORDER BY card.id
-    <trim prefix="limit " >
-      <if test="start != null and count != null">
-        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
-      </if>
-    </trim>
-  </select>
-  <!--鏍规嵁鍐滄埛ID鏌ヨ姝e父鐘舵�佺殑姘村崱鍒楄〃,灏忕▼搴忎娇鐢�-->
-  <select id="getCardsByClientID" resultType="com.dy.pipIrrGlobal.voWe.VoCards3">
-    SELECT
-    card.id AS clientCardId,
-    cli.id AS clientId,
-    cli.clientNum,
-    cli.name AS clientName,
-    card.cardNum,
-    cli.phone,
-    cli.idCard,
-    card.state AS cardState,
-    (CASE
-    WHEN card.state = 1 THEN '姝e父'
-    WHEN card.state = 2 THEN '宸叉敞閿�'
-    WHEN card.state = 3 THEN '宸叉寕澶�'
-    End) AS stateName,
-    '鍐滄埛鍗�' AS cardType,
-    FORMAT(card.money, 2) AS money
-    FROM se_client_card card
-    INNER JOIN se_client cli ON card.clientId = cli.id
-    where
-      card.state = 1
-      AND cli.id like CONCAT('%',#{clientId},'%')
+    <!--渚濇嵁姘村崱鍦板潃鑾峰彇姘村崱缂栧彿锛�12鏈�19鏃ュ簾寮冿級-->
+    <select id="getCardIdByAddr" resultType="java.lang.Long">
+        SELECT id AS cardId
+        FROM se_client_card
+        WHERE cardAddr = #{cardAddr}
+    </select>
+
+    <!--鏍规嵁姘村崱缂栧彿鑾峰彇姘村崱琛ㄤ富閿紙12鏈�19鏃ユ坊鍔犲悗搴熷純锛�-->
+    <select id="getCardIdByNum" resultType="java.lang.Long">
+        SELECT id AS cardId
+        FROM se_client_card
+        WHERE cardNum = #{cardNum}
+    </select>
+
+    <!--鏍规嵁姘村崱缂栧彿鑾峰彇姘村崱琛ㄤ富閿強鍐滄埛缂栧彿-->
+    <select id="getCardIdAndClientNum" resultType="java.util.Map">
+        <!--    SELECT id AS cardId, clientNum FROM se_client_card WHERE cardNum = #{cardNum}-->
+        SELECT card.id AS cardId,
+               cli.clientNum,
+               cli.id  AS clientId,
+               protocol
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        WHERE card.cardNum = #{cardNum}
+    </select>
+
+    <!-- 鏍规嵁姘村崱缂栧彿鑾峰彇姘村崱瀵瑰簲鐨勫啘鎴穒d鍜屽鍚� -->
+    <select id="getClientIdAndNameByCardAddrAndCardNo" resultType="java.util.Map">
+        SELECT cli.id   AS clientId,
+               cli.name AS clientName
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        WHERE card.cardAddr = #{cardAddr}
+          and card.cardNum = #{cardNum}
+    </select>
 
 
-    ORDER BY card.id
-  </select>
+    <!-- 鏍规嵁姘村崱缂栧彿鑾峰彇姘村崱 -->
+    <select id="getCardsByAddrAndNum" resultType="com.dy.pipIrrGlobal.voSe.VoCardInfo1">
+        SELECT id,
+               money
+        FROM se_client_card
+        WHERE cardAddr = #{cardAddr}
+          and cardNum = #{cardNum}
+    </select>
+
+    <!--鏍规嵁琛屾斂鍖哄垝涓叉ā绯婃煡璇㈡按鍗$紪鍙�-->
+    <select id="getCardNumOfMax" resultType="java.lang.String">
+        SELECT cardNum
+        FROM se_client_card
+        WHERE cardNum LIKE CONCAT(#{areaCode}, '%')
+        ORDER BY cardNum desc
+        LIMIT 0,1
+    </select>
+
+    <insert id="insert" keyColumn="id" keyProperty="id" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
+        <!--@mbg.generated-->
+        insert into se_client_card (id, protocol, cardAddr, cardNum, clientId,
+                                    money, `state`, original_card_id, createDt,
+                                    replaceDt, rechargeDt, lossDtDt,
+                                    cancelDt, unlockDt, reversalDt, refundDt,
+                                    consumeDt, lastOper, remarks)
+        values (#{id,jdbcType=BIGINT}, #{protocol,jdbcType=VARCHAR}, #{cardaddr,jdbcType=VARCHAR},
+                #{cardnum,jdbcType=BIGINT}, #{clientid,jdbcType=BIGINT},
+                #{money,jdbcType=FLOAT}, #{state,jdbcType=TINYINT}, #{originalCardId,jdbcType=BIGINT},
+                #{createdt,jdbcType=TIMESTAMP},
+                #{replacedt,jdbcType=TIMESTAMP}, #{rechargedt,jdbcType=TIMESTAMP}, #{lossdtdt,jdbcType=TIMESTAMP},
+                #{canceldt,jdbcType=TIMESTAMP}, #{unlockdt,jdbcType=TIMESTAMP}, #{reversaldt,jdbcType=TIMESTAMP},
+                #{refunddt,jdbcType=TIMESTAMP}, #{consumedt,jdbcType=TIMESTAMP}, #{lastoper,jdbcType=TINYINT},
+                #{remarks,jdbcType=VARCHAR})
+    </insert>
+    <insert id="insertSelective" keyColumn="id" keyProperty="id" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard"
+            useGeneratedKeys="true">
+        <!--@mbg.generated-->
+        insert into se_client_card
+        <trim prefix="(" suffix=")" suffixOverrides=",">
+            <if test="id != null">
+                id,
+            </if>
+            <if test="protocol != null">
+                protocol,
+            </if>
+            <if test="cardaddr != null">
+                cardAddr,
+            </if>
+            <if test="cardnum != null">
+                cardNum,
+            </if>
+            <if test="clientid != null">
+                clientId,
+            </if>
+            <if test="money != null">
+                money,
+            </if>
+            <if test="state != null">
+                `state`,
+            </if>
+            <if test="originalCardId != null">
+                original_card_id,
+            </if>
+            <if test="createdt != null">
+                createDt,
+            </if>
+            <if test="replacedt != null">
+                replaceDt,
+            </if>
+            <if test="rechargedt != null">
+                rechargeDt,
+            </if>
+            <if test="lossdtdt != null">
+                lossDtDt,
+            </if>
+            <if test="canceldt != null">
+                cancelDt,
+            </if>
+            <if test="unlockdt != null">
+                unlockDt,
+            </if>
+            <if test="reversaldt != null">
+                reversalDt,
+            </if>
+            <if test="refunddt != null">
+                refundDt,
+            </if>
+            <if test="consumedt != null">
+                consumeDt,
+            </if>
+            <if test="lastoper != null">
+                lastOper,
+            </if>
+            <if test="remarks != null">
+                remarks,
+            </if>
+        </trim>
+        <trim prefix="values (" suffix=")" suffixOverrides=",">
+            <if test="id != null">
+                #{id,jdbcType=BIGINT},
+            </if>
+            <if test="protocol != null">
+                #{protocol,jdbcType=VARCHAR},
+            </if>
+            <if test="cardaddr != null">
+                #{cardaddr,jdbcType=VARCHAR},
+            </if>
+            <if test="cardnum != null">
+                #{cardnum,jdbcType=BIGINT},
+            </if>
+            <if test="clientid != null">
+                #{clientid,jdbcType=BIGINT},
+            </if>
+            <if test="money != null">
+                #{money,jdbcType=FLOAT},
+            </if>
+            <if test="state != null">
+                #{state,jdbcType=TINYINT},
+            </if>
+            <if test="originalCardId != null">
+                #{originalCardId,jdbcType=BIGINT},
+            </if>
+            <if test="createdt != null">
+                #{createdt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="replacedt != null">
+                #{replacedt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="rechargedt != null">
+                #{rechargedt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="lossdtdt != null">
+                #{lossdtdt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="canceldt != null">
+                #{canceldt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="unlockdt != null">
+                #{unlockdt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="reversaldt != null">
+                #{reversaldt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="refunddt != null">
+                #{refunddt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="consumedt != null">
+                #{consumedt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="lastoper != null">
+                #{lastoper,jdbcType=TINYINT},
+            </if>
+            <if test="remarks != null">
+                #{remarks,jdbcType=VARCHAR},
+            </if>
+        </trim>
+    </insert>
+    <update id="updateByPrimaryKeySelective" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
+        <!--@mbg.generated-->
+        update se_client_card
+        <set>
+            <if test="protocol != null">
+                protocol = #{protocol,jdbcType=VARCHAR},
+            </if>
+            <if test="cardaddr != null">
+                cardAddr = #{cardaddr,jdbcType=VARCHAR},
+            </if>
+            <if test="cardnum != null">
+                cardNum = #{cardnum,jdbcType=BIGINT},
+            </if>
+            <if test="clientid != null">
+                clientId = #{clientid,jdbcType=BIGINT},
+            </if>
+            <if test="money != null">
+                money = #{money,jdbcType=FLOAT},
+            </if>
+            <if test="state != null">
+                `state` = #{state,jdbcType=TINYINT},
+            </if>
+            <if test="originalCardId != null">
+                `original_card_id` = #{originalCardId,jdbcType=BIGINT},
+            </if>
+            <if test="createdt != null">
+                createDt = #{createdt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="replacedt != null">
+                replaceDt = #{replacedt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="rechargedt != null">
+                rechargeDt = #{rechargedt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="lossdtdt != null">
+                lossDtDt = #{lossdtdt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="canceldt != null">
+                cancelDt = #{canceldt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="unlockdt != null">
+                unlockDt = #{unlockdt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="reversaldt != null">
+                reversalDt = #{reversaldt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="refunddt != null">
+                refundDt = #{refunddt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="consumedt != null">
+                consumeDt = #{consumedt,jdbcType=TIMESTAMP},
+            </if>
+            <if test="lastoper != null">
+                lastOper = #{lastoper,jdbcType=TINYINT},
+            </if>
+            <if test="remarks != null">
+                remarks = #{remarks,jdbcType=VARCHAR},
+            </if>
+        </set>
+        where id = #{id,jdbcType=BIGINT}
+    </update>
+    <update id="updateByPrimaryKey" parameterType="com.dy.pipIrrGlobal.pojoSe.SeClientCard">
+        <!--@mbg.generated-->
+        update se_client_card
+        set protocol         = #{protocol,jdbcType=VARCHAR},
+            cardAddr         = #{cardaddr,jdbcType=VARCHAR},
+            cardNum          = #{cardnum,jdbcType=BIGINT},
+            clientId         = #{clientid,jdbcType=BIGINT},
+            money            = #{money,jdbcType=FLOAT},
+            `state`          = #{state,jdbcType=TINYINT},
+            original_card_id = #{originalCardId,jdbcType=BIGINT},
+            createDt         = #{createdt,jdbcType=TIMESTAMP},
+            replaceDt        = #{replacedt,jdbcType=TIMESTAMP},
+            rechargeDt       = #{rechargedt,jdbcType=TIMESTAMP},
+            lossDtDt         = #{lossdtdt,jdbcType=TIMESTAMP},
+            cancelDt         = #{canceldt,jdbcType=TIMESTAMP},
+            unlockDt         = #{unlockdt,jdbcType=TIMESTAMP},
+            reversalDt       = #{reversaldt,jdbcType=TIMESTAMP},
+            refundDt         = #{refunddt,jdbcType=TIMESTAMP},
+            consumeDt        = #{consumedt,jdbcType=TIMESTAMP},
+            lastOper         = #{lastoper,jdbcType=TINYINT},
+            remarks          = #{remarks,jdbcType=VARCHAR}
+        where id = #{id,jdbcType=BIGINT}
+    </update>
+    <update id="updateMoney">
+        update se_client_card
+        set money = #{money,jdbcType=FLOAT}
+        where id = #{id,jdbcType=BIGINT}
+    </update>
+    <!--鏍规嵁鍐滄埛涓婚敭鑾峰彇姘村崱鍒楄〃锛堢墿鐞嗗崱+铏氭嫙鍗★級-->
+    <select id="getCardInfoByClientId" resultType="com.dy.pipIrrGlobal.voSe.VoCardInfo">
+        SELECT *
+        FROM (SELECT '鐗╃悊鍗�'        AS cardType,
+                     card.cardNum AS cardNum,
+                     card.money   AS money,
+                     (CASE
+                          WHEN card.state = 1 THEN '姝e父'
+                          WHEN card.state = 2 THEN '宸叉敞閿�'
+                          ELSE '宸叉寕澶�'
+                         END)     AS state
+              FROM se_client_card card
+                       INNER JOIN se_client cli ON cli.id = card.clientId
+              WHERE card.clientId = #{clientId,jdbcType=BIGINT}
+              UNION ALL
+              SELECT '铏氭嫙鍗�'     AS cardType,
+                     vc.vc_num AS cardNum,
+                     vc.money  AS money,
+                     (CASE
+                          WHEN vc.in_use = 0 THEN '鏈娇鐢�'
+                          WHEN vc.in_use = 1 THEN '浣跨敤涓�'
+                         END)  AS state
+              FROM se_virtual_card vc
+                       INNER JOIN se_client cli ON cli.id = vc.client_id
+              WHERE vc.client_id = #{clientId,jdbcType=BIGINT}
+        <!--              SELECT '铏氭嫙鍗�'              AS cardType,-->
+        <!--                     virtualCard.vc_num AS CardNum,-->
+        <!--                     virtualCard.money  AS vcMoney,-->
+        <!--                     (CASE-->
+        <!--                          WHEN virtualCard.in_use = 0 THEN '鏈娇鐢�'-->
+        <!--                          WHEN virtualCard.in_use = 1 THEN '浣跨敤涓�'-->
+        <!--                         END)           AS State-->
+        <!--              FROM se_client client-->
+        <!--                       LEFT JOIN se_virtual_card virtualCard ON client.id = virtualCard.client_id-->
+        <!--              WHERE client.id = #{clientId,jdbcType=BIGINT}-->
+        ) card
+        ORDER BY card.Money DESC, card.State DESC
+    </select>
+
+    <!--鏍规嵁姘村崱缂栧彿鑾峰彇鎿嶄綔璁板綍鍒楄〃-->
+    <select id="getOperateRecordsByCardNum" resultType="java.util.HashMap">
+        SELECT *
+        FROM v_operate
+        WHERE cardNum = #{cardNum,jdbcType=BIGINT}
+    </select>
+
+    <!--鏍规嵁姘村崱缂栧彿鑾峰彇浣欓-->
+    <select id="getMoneyByCardNum" resultType="java.lang.Float">
+        SELECT money
+        FROM se_client_card
+        WHERE cardNum = #{cardNum,jdbcType=BIGINT}
+    </select>
+
+    <!--鏍规嵁姘村崱缂栧彿鑾峰彇鍏呭�兼�婚-->
+    <select id="sumRechargeByCardNum" resultType="java.lang.Float">
+        SELECT SUM(his.amount) AS amount
+        FROM se_recharge_history his
+                 INNER JOIN se_client_card card ON his.cardId = card.id
+        WHERE card.cardNum = #{cardNum,jdbcType=BIGINT}
+    </select>
+
+    <!--鏍规嵁姘村崱缂栧彿鑾峰彇鍗$墖鐘舵�侊細1-寮�鍗★紝2-琛ュ崱锛�3-鍏呭�硷紝4-鎸傚け锛�5-娉ㄩ攢锛�6-瑙i攣锛�7-鍐叉锛�8-娑堣垂-->
+    <select id="getCardStateByCardNum" resultType="java.lang.String">
+        <!--    SELECT-->
+        <!--      (CASE-->
+        <!--         WHEN lastOper = 1 THEN "寮�鍗�"-->
+        <!--         WHEN lastOper = 2 THEN "琛ュ崱"-->
+        <!--         WHEN lastOper = 3 THEN "鍏呭��"-->
+        <!--         WHEN lastOper = 4 THEN "鎸傚け"-->
+        <!--         WHEN lastOper = 5 THEN "娉ㄩ攢"-->
+        <!--         WHEN lastOper = 6 THEN "瑙i攣"-->
+        <!--         WHEN lastOper = 7 THEN "鍐叉"-->
+        <!--         WHEN lastOper = 8 THEN "娑堣垂"-->
+        <!--        END) AS stateName-->
+        <!--    FROM se_client_card-->
+        <!--    WHERE cardNum = ${cardNum}-->
+        SELECT (CASE
+                    WHEN state = 1 THEN '姝e父'
+                    WHEN state = 2 THEN '宸叉敞閿�'
+                    WHEN state = 3 THEN '宸叉寕澶�'
+            END) AS stateName
+        FROM se_client_card
+        WHERE cardNum = #{cardNum,jdbcType=BIGINT}
+    </select>
+
+    <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇姘村崱鍒楄〃璁板綍鏁帮紝搴旂敤绋嬪簭浣跨敤-->
+    <select id="getCardsCount" parameterType="java.util.Map" resultType="java.lang.Long">
+        SELECT COUNT(*) AS recordCount
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        <where>
+            AND card.state = 1
+            <if test="clientNum != null and clientNum != ''">
+                AND cli.clientNum like CONCAT('%', #{clientNum}, '%')
+            </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>
+        </where>
+    </select>
+
+    <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇姘村崱鍒楄〃锛屽簲鐢ㄧ▼搴忎娇鐢�-->
+    <select id="getCards" resultType="com.dy.pipIrrGlobal.voSe.VoCards">
+        SELECT cli.clientNum,
+               cli.name AS clientName,
+               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,-->
+        cli.phone,
+        cli.idCard,
+        card.state AS cardState,
+        <!--        (CASE-->
+        <!--            WHEN card.state = 1 THEN '姝e父'-->
+        <!--            WHEN card.state = 2 THEN '宸叉敞閿�'-->
+        <!--            WHEN card.state = 3 THEN '宸叉寕澶�'-->
+        <!--        End) AS stateName,-->
+        '姝e父'                  AS stateName,
+        '鍐滄埛鍗�'                 AS cardType,
+        FORMAT(card.money, 2) AS money
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        <where>
+            AND card.state = 1
+            <if test="clientNum != null and clientNum != ''">
+                AND cli.clientNum like CONCAT('%', #{clientNum}, '%')
+            </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>
+        </where>
+        ORDER BY card.id
+        <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="getUnreplacedRecordCount" resultType="java.lang.Long">
+        SELECT COUNT(*) AS recordCount
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        WHERE card.state = 3
+          AND NOT EXISTS(SELECT * FROM se_client_card card2 WHERE card2.original_card_id = card.cardNum)
+    </select>
+
+    <!--鑾峰彇宸叉寕澶辨湭琛ュ崱鐨勮褰�-->
+    <select id="getUnreplaced" resultType="com.dy.pipIrrGlobal.voSe.VoCards">
+        SELECT cli.clientNum,
+               cli.name AS clientName,
+               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,-->
+        cli.phone,
+        cli.idCard,
+        card.state            AS cardState,
+        '宸叉寕澶�'                 AS stateName,
+        '鍐滄埛鍗�'                 AS cardType,
+        FORMAT(card.money, 2) AS money
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        WHERE card.state = 3
+          AND NOT EXISTS(SELECT * FROM se_client_card card2 WHERE card2.original_card_id = card.id)
+        ORDER BY card.id
+        <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="getLostCount" resultType="java.lang.Integer">
+        SELECT COUNT(*) AS recordCount
+        FROM se_client_card card
+        <where>
+            AND card.state = 3
+            <if test="cardNum != null and cardNum > 0">
+                AND card.cardNum = #{cardNum}
+            </if>
+        </where>
+    </select>
+
+    <!--鏍规嵁鎸囧畾姘村崱缂栧彿鑾峰彇宸茶ˉ鍗℃暟閲忥紙琛ュ崱銆佽В閿佷娇鐢級-->
+    <select id="getReplacedCount" resultType="java.lang.Integer">
+        SELECT COUNT(*) AS recordCount
+        FROM se_client_card card
+                 INNER JOIN se_client_card card2 ON card2.original_card_id = card.id
+        <where>
+            <if test="cardNum != null and cardNum > 0">
+                AND card.cardNum = #{cardNum}
+            </if>
+        </where>
+    </select>
+    <!--鏍规嵁鍐滄埛濮撳悕鍜屾墜鏈哄彿鑾峰彇姘村崱鍒楄〃璁板綍鏁帮紝搴旂敤绋嬪簭浣跨敤-->
+    <select id="getCardsByClientNameAndPhoneCount" resultType="java.lang.Long">
+        SELECT COUNT(*) AS recordCount
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        <where>
+            card.state = 1
+            <if test="clientName != null and clientName != ''">
+                AND cli.name like CONCAT('%', #{clientName}, '%')
+            </if>
+
+            <if test="phone != null and phone != ''">
+                AND cli.phone like CONCAT('%', #{phone}, '%')
+            </if>
+        </where>
+    </select>
+    <!--鏍规嵁鍐滄埛濮撳悕鍜屾墜鏈哄彿鑾峰彇姘村崱鍒楄〃锛屽簲鐢ㄧ▼搴忎娇鐢�-->
+    <select id="getCardsByClientNameAndPhone" resultType="com.dy.pipIrrGlobal.voSe.VoCards2">
+        SELECT card.id               AS clientCardId,
+               cli.id                AS clientId,
+               cli.clientNum,
+               cli.name              AS clientName,
+               card.cardNum,
+               cli.phone,
+               cli.idCard,
+               card.state            AS cardState,
+               (CASE
+                    WHEN card.state = 1 THEN '姝e父'
+                    WHEN card.state = 2 THEN '宸叉敞閿�'
+                    WHEN card.state = 3 THEN '宸叉寕澶�'
+                   End)              AS stateName,
+               '鍐滄埛鍗�'                 AS cardType,
+               FORMAT(card.money, 2) AS money
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        <where>
+            card.state = 1
+            <if test="clientName != null and clientName != ''">
+                AND cli.name like CONCAT('%', #{clientName}, '%')
+            </if>
+
+            <if test="phone != null and phone != ''">
+                AND cli.phone like CONCAT('%', #{phone}, '%')
+            </if>
+        </where>
+        ORDER BY card.id
+        <trim prefix="limit ">
+            <if test="start != null and count != null">
+                #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+            </if>
+        </trim>
+    </select>
+    <!--鏍规嵁鍐滄埛ID鏌ヨ姝e父鐘舵�佺殑姘村崱鍒楄〃,灏忕▼搴忎娇鐢�-->
+    <select id="getCardsByClientID" resultType="com.dy.pipIrrGlobal.voWe.VoCards3">
+        SELECT card.id               AS clientCardId,
+               cli.id                AS clientId,
+               cli.clientNum,
+               cli.name              AS clientName,
+               card.cardNum,
+               cli.phone,
+               cli.idCard,
+               card.state            AS cardState,
+               (CASE
+                    WHEN card.state = 1 THEN '姝e父'
+                    WHEN card.state = 2 THEN '宸叉敞閿�'
+                    WHEN card.state = 3 THEN '宸叉寕澶�'
+                   End)              AS stateName,
+               '鍐滄埛鍗�'                 AS cardType,
+               FORMAT(card.money, 2) AS money
+        FROM se_client_card card
+                 INNER JOIN se_client cli ON card.clientId = cli.id
+        where card.state = 1
+          AND cli.id like CONCAT('%', #{clientId}, '%')
+
+
+        ORDER BY card.id
+    </select>
+    <!--褰撳墠浣欓鎬婚噺锛堢墿鐞嗗崱锛�-->
+    <select id="getTotalMoneyIcCards" resultType="java.lang.Double">
+        SELECT IFNULL(SUM(money), 0) AS totalMoney
+        FROM `se_client_card`
+        WHERE state = 1
+    </select>
+
+    <!--鏍规嵁姘村崱鍦板潃鑾峰彇姘村崱鏁伴噺-->
+    <select id="getCountByCardAddr" resultType="java.lang.Long">
+        SELECT COUNT(*) AS recordCount
+        FROM se_client_card
+        WHERE cardAddr = #{cardAddr}
+    </select>
+
+    <!--鏍规嵁姘村崱鍦板潃鑾峰彇鎸囧畾鐘舵�佺殑姘村崱鏁伴噺-->
+    <select id="getCountByCardAddrAndState" resultType="java.lang.Long">
+        SELECT COUNT(*) AS recordCount
+        FROM se_client_card
+        WHERE cardAddr = #{cardAddr}
+          AND state IN (1, 3)
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0