From 5071992d0f6935288bf5f9f772a423dde3c0b8d3 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 21 May 2025 11:15:07 +0800
Subject: [PATCH] refactor(mall): 优化会员收藏商品的删除逻辑

---
 src/main/resources/mapper/modules/HappyActivityOptionMapper.xml |  179 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 173 insertions(+), 6 deletions(-)

diff --git a/src/main/resources/mapper/modules/HappyActivityOptionMapper.xml b/src/main/resources/mapper/modules/HappyActivityOptionMapper.xml
index be37767..05101e2 100644
--- a/src/main/resources/mapper/modules/HappyActivityOptionMapper.xml
+++ b/src/main/resources/mapper/modules/HappyActivityOptionMapper.xml
@@ -8,9 +8,10 @@
             a.address,
             a.index_img,
             a.code,
+            a.type,
             a.name,
             a.state,
-            a.join_cnt,
+            (select count(z.id) from happy_follow z where z.source_id = a.id AND z.type IN (2, 3, 4)) as join_cnt,
             a.start_time,
             a.end_time
         from happy_activity a
@@ -29,7 +30,13 @@
                 </if>
             </if>
         </where>
-        order by a.order_cnt asc, a.id desc
+        <if test="record.hotState != null">
+            order by (select count(y.id) from happy_follow y where y.source_id = a.id and type in (2, 3, 4)) desc,a.order_cnt asc
+        </if>
+        <if test="record.hotState == null">
+            order by a.order_cnt asc,a.id desc
+        </if>
+
     </select>
 
     <select id="getVoteRecordInPage" resultType="cc.mrbird.febs.mall.vo.ApiVoteRecordInPageVo">
@@ -48,18 +55,178 @@
         update happy_activity_option set likes_cnt = likes_cnt + 1 where id = #{id}
     </update>
 
+
+    <update id="updateHappyActivitySurplusCnt" >
+        update happy_activity set surplus_cnt = surplus_cnt + #{cnt} where id = #{id}
+    </update>
+
     <select id="getVoteOptionInPage" resultType="cc.mrbird.febs.mall.vo.ApiActivityOptionListVo">
         select
             a.id as id,
+            a.order_cnt as orderCnt,
             a.option_name as optionName,
             a.image as image,
             a.likes_cnt as likesCnt
         from happy_activity_option a
-        where
-            a.state = 1
-          and a.activity_id = #{record.activityId}
-          and a.DELETE_FLAG = 1
+        <where>
+            and a.state = 1
+            and a.activity_id = #{record.activityId}
+            and a.DELETE_FLAG = 0
+            <if test="record != null">
+                <if test="record.query != null and record.query != ''">
+                    and (
+                    a.option_name like CONCAT('%', CONCAT(#{record.query}, '%'))
+                    or
+                    a.order_cnt = #{record.query}
+                    )
+                </if>
+            </if>
+        </where>
         order by a.order_cnt asc
     </select>
 
+    <select id="selectOrderInPage" resultType="cc.mrbird.febs.mall.entity.HappyActivityOrder">
+        select
+        a.*,
+               b.name as name,
+               c.name as activityName
+        from happy_activity_order a
+        left join mall_member b on a.member_id = b.id
+        left join happy_activity c on a.activity_id = c.id
+        <where>
+            and a.DELETE_FLAG = 0
+            <if test="record != null">
+                <if test="record.name != null and record.name != ''">
+                    and b.name like CONCAT('%', CONCAT(#{record.name}, '%'))
+                </if>
+                <if test="record.state != null">
+                    and a.state=#{record.state}
+                </if>
+                <if test="record.activityId != null">
+                    and a.activity_id=#{record.activityId}
+                </if>
+            </if>
+        </where>
+        order by a.id desc
+    </select>
+
+
+
+    <select id="getVoteOptionRecordInPage" resultType="cc.mrbird.febs.mall.vo.ApiActivityOptionListVo">
+        select
+        a.id as id,
+        a.option_name as optionName,
+        a.image as image,
+        a.likes_cnt as likesCnt
+        from happy_activity_option a
+        <where>
+            and a.state = 1
+            and a.activity_id = #{record.activityId}
+            and a.DELETE_FLAG = 0
+            <if test="record != null">
+                <if test="record.query != null and record.query != ''">
+                    and (
+                    a.option_name like CONCAT('%', CONCAT(#{record.query}, '%'))
+                    or
+                    a.order_cnt = #{record.query}
+                    )
+                </if>
+            </if>
+        </where>
+        order by a.likes_cnt desc
+    </select>
+
+    <select id="selectActivityCommentPage" resultType="cc.mrbird.febs.mall.vo.activity.ApiActivityCommentVo">
+        select
+        a.*,
+        b.name name,
+        b.avatar avatar
+        from happy_activity_comment a
+        left join mall_member b on b.id = a.member_id
+        <where>
+            <if test="record != null">
+                <if test="record.activityId != null and record.activityId != ''">
+                    and a.activity_id = #{record.activityId}
+                </if>
+                <if test="record.commentType != null and record.commentType != '' and record.commentType == 1">
+                    and a.star <![CDATA[ > ]]> 4
+                </if>
+                <if test="record.commentType != null and record.commentType != '' and record.commentType == 2">
+                    and (a.star <![CDATA[ >= ]]> 3 and a.star <![CDATA[ <= ]]> 4)
+                </if>
+                <if test="record.commentType != null and record.commentType != '' and record.commentType == 3">
+                    and (a.star <![CDATA[ < ]]> 3 )
+                </if>
+            </if>
+        </where>
+        group by a.id
+        order by a.created_time desc
+    </select>
+
+
+
+    <select id="getCommentListInPage" resultType="cc.mrbird.febs.mall.vo.activity.AdminActivityCommentVo">
+        select
+               a.*,
+                b.name memberName,
+                c.order_no orderNo
+        from happy_activity_comment a
+        left join mall_member b on a.member_id = b.id
+        left join happy_activity_order c on a.order_id = c.id
+        where a.activity_id = #{record.activityId}
+        order by a.created_time desc
+    </select>
+
+    <select id="activityOrderCheckList" resultType="cc.mrbird.febs.mall.vo.activity.AdminHappyActivityOrderCheckVo">
+        select
+        a.id,
+        a.code,
+        a.name,
+        a.phone,
+        a.address,
+        a.state,
+        CASE
+        WHEN a.state = 1 THEN a.UPDATED_TIME
+        ELSE NULL
+        END AS updatedTime,
+        b.name checkName,
+        b.phone checkPhone,
+        b.real_name checkRealName
+        from happy_activity_order_item a
+        left join mall_member b on b.id = a.transfer_item_id
+        <where>
+
+            and a.code is not null
+            <if test="record != null">
+                <if test="record.name != null and record.name != ''">
+                    and (b.name like CONCAT('%', CONCAT(#{record.name}, '%'))
+                    or b.real_name like CONCAT('%', CONCAT(#{record.name}, '%')))
+                </if>
+                <if test="record.code != null and record.code != ''">
+                    and a.code = #{record.code}
+                </if>
+                <if test="record.state != null">
+                    and a.state=#{record.state}
+                </if>
+                <if test="record.activityId != null">
+                    and a.activity_id=#{record.activityId}
+                </if>
+            </if>
+        </where>
+        order by a.created_time desc
+    </select>
+
+    <select id="getOrderCheckListForExport" resultType="cc.mrbird.febs.mall.vo.activity.AdminHappyActivityOrderCheckVo">
+        select
+        a.*,
+        b.name checkName,
+        b.phone checkPhone,
+        b.real_name checkRealName
+        from happy_activity_order_item a
+        left join mall_member b on b.id = a.transfer_item_id
+        where a.code is not null
+        and a.activity_id=#{activityId}
+        order by a.created_time desc
+    </select>
+
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.1