From ad8fc09f3e70b08cd654d38ff9aa9022c2c2c6ec Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Wed, 10 Nov 2021 10:26:40 +0800
Subject: [PATCH] fix

---
 gc-shop/src/main/resources/mapper/shop/ScoreOrderMapper.xml |  102 ++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 97 insertions(+), 5 deletions(-)

diff --git a/gc-shop/src/main/resources/mapper/shop/ScoreOrderMapper.xml b/gc-shop/src/main/resources/mapper/shop/ScoreOrderMapper.xml
index 6a8941d..e76a47d 100644
--- a/gc-shop/src/main/resources/mapper/shop/ScoreOrderMapper.xml
+++ b/gc-shop/src/main/resources/mapper/shop/ScoreOrderMapper.xml
@@ -6,9 +6,11 @@
         SELECT
                a.*,
                a.CREATED_TIME createTime,
-               b.name name,
+               ifnull(a.is_finish,2) isFinish,
+               b.nick_name name,
                b.mobile_phone phone,
                d.express_com expressCom,
+               d.address expressAddress,
                d.express_no expressNo
         FROM
         xzx_score_order a
@@ -20,10 +22,14 @@
         </if>
 
         <if test="name != null and name != ''">
-            and b.name like concat('%',#{name},'%')
+            and (b.nick_name like concat('%',#{name},'%')
+                     or b.mobile_phone like concat('%',#{accountName},'%') )
         </if>
-        <if test="status != null and status != ''">
-            and a.status = #{status}
+        <if test="status.size > 0">
+            and a.status in
+            <foreach collection="status" item="sta" open="(" separator="," close=")">
+                #{sta}
+            </foreach>
         </if>
         <if test="createdTimeStart != null">
             and a.CREATED_TIME >= #{createdTimeStart}
@@ -32,7 +38,93 @@
         <if test="createdTimeEnd != null">
             and a.CREATED_TIME &lt;= #{createdTimeEnd}
         </if>
-        order by a.CREATED_TIME desc
+        order by
+            <if test="namePx != null and namePx != '' and namePx == 1">
+                a.CREATED_TIME
+            </if>
+            <if test="namePx != null and namePx != '' and namePx == 2">
+                from_base64(b.nick_name)
+            </if>
+
+            <if test="typePx != null and typePx != '' and typePx == 1">
+                asc
+            </if>
+            <if test="typePx != null and typePx != '' and typePx == 2">
+                desc
+            </if>
+
     </select>
 
+    <select id="selectXcxOrderList" resultType="com.xzx.gc.shop.vo.XcxOrderListVo">
+        select
+            a.*,
+            b.unit_price,
+            b.sku,
+            b.style,
+            b.thumb
+        from xzx_score_order a
+        inner join xzx_score_order_details b on a.id=b.order_id
+        <where>
+            a.user_id=#{record.userId}
+            <if test="record.status == 1">
+                and a.status in (1, 2, 3)
+            </if>
+            <if test="record.status == 2">
+                and a.status = 4
+            </if>
+            <if test="record.status == 3">
+                and a.status = 6
+            </if>
+        </where>
+        order by a.created_time desc
+    </select>
+
+    <select id="selectXcxOrderDetails" resultType="com.xzx.gc.shop.vo.XcxOrderDetailsVo">
+        select
+            a.*
+             ,b.style
+             ,b.sku
+             ,b.thumb
+             ,b.unit_price
+             ,c.address
+             ,c.phone
+             ,c.username
+             ,c.express_com expressCompany
+             ,c.express_no
+        from xzx_score_order a
+         inner join xzx_score_order_details b on a.id=b.order_id
+         inner join xzx_score_express_info c on a.id=c.order_id
+        where a.id=#{id}
+    </select>
+
+    <update id="updateOrderStatus">
+        update xzx_score_order
+        set status=#{status}
+        where id=#{id} and user_id=#{userId}
+    </update>
+
+    <select id="selectOrderStastics" resultType="java.util.Map">
+        select
+            IFNULL(count(1), 0) totalBuy,
+            IFNULL(sum(IFNULL(total_price,0)),0) totalPrice,
+            (
+                select IFNULL(count(1),0) from xzx_jhy_order where status in (3, 4)
+                <if test="userId != null and userId != ''">
+                    and user_id=#{userId}
+                </if>
+            ) totalOrder
+        from xzx_score_order
+        where status in (3, 4)
+        <if test="userId != null and userId != ''">
+            and user_id=#{userId}
+        </if>
+    </select>
+
+    <select id="selectScoreOrderCnt" resultType="java.lang.Integer">
+        select IFNULL(count(1), 0) from xzx_score_order
+        where status in (3, 4)
+        <if test="userId != null and userId != ''">
+            and user_id=#{userId}
+        </if>
+    </select>
 </mapper>

--
Gitblit v1.9.1