From 75b1a93d2c447b3c9fc1de95270694ebdac6faca Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期六, 07 十月 2023 13:51:06 +0800
Subject: [PATCH] 优化

---
 ard-work/src/main/resources/mapper/app/ArdAppTaskMapper.xml |  101 +++++++++++++++++++++++++++++---------------------
 1 files changed, 59 insertions(+), 42 deletions(-)

diff --git a/ard-work/src/main/resources/mapper/app/ArdAppTaskMapper.xml b/ard-work/src/main/resources/mapper/app/ArdAppTaskMapper.xml
index 36de4bf..c2f0eb0 100644
--- a/ard-work/src/main/resources/mapper/app/ArdAppTaskMapper.xml
+++ b/ard-work/src/main/resources/mapper/app/ArdAppTaskMapper.xml
@@ -6,6 +6,7 @@
 
     <resultMap type="ArdAppTask" id="ArdAppTaskResult">
         <result property="id" column="id"/>
+        <result property="type" column="type"/>
         <result property="name" column="name"/>
         <result property="text" column="text"/>
         <result property="voice" column="voice"/>
@@ -17,6 +18,12 @@
         <result property="updateTime" column="update_time"/>
     </resultMap>
     <resultMap id="ArdAppTaskSubResult" type="ArdAppTask" extends="ArdAppTaskResult">
+        <collection property="ardAppTaskDetailList" column="{id=id,detailUserId=detail_user_id}"
+                    select="selectArdAppTaskDetailListByIdAndUserId"/>
+        <collection property="ardAppTaskPicList" column="id"
+                    select="selectArdAppTaskPicListById"/>
+    </resultMap>
+    <resultMap id="ArdAppTaskSub1Result" type="ArdAppTask" extends="ArdAppTaskResult">
         <collection property="ardAppTaskPicList" notNullColumn="sub2_id" javaType="java.util.List"
                     resultMap="ArdAppTaskPicResult"/>
         <collection property="ardAppTaskDetailList" notNullColumn="sub1_id" javaType="java.util.List"
@@ -44,17 +51,10 @@
         <result property="taskId" column="sub2_task_id"/>
         <result property="picUrl" column="sub2_pic_url"/>
     </resultMap>
-    <resultMap id="ArdAppTaskArdAppTaskPicResult" type="ArdAppTask" extends="ArdAppTaskResult">
-        <collection property="ardAppTaskPicList" notNullColumn="sub_id" javaType="java.util.List"
-                    resultMap="ArdAppTaskPicResult"/>
-    </resultMap>
-    <resultMap id="ArdAppTaskArdAppTaskDetailResult" type="ArdAppTask" extends="ArdAppTaskResult">
-        <collection property="ardAppTaskDetailList" notNullColumn="sub_id" javaType="java.util.List"
-                    resultMap="ArdAppTaskDetailResult"/>
-    </resultMap>
 
     <sql id="selectArdAppTaskVo">
         select c.id,
+               c.type,
                c.name,
                c.text,
                c.voice,
@@ -63,15 +63,14 @@
                c.create_by,
                c.create_time,
                c.update_by,
-               c.update_time,
-               c.view_time,
-               c.view_position
+               c.update_time
         from ard_app_task c
                  left join sys_dept d on d.dept_id = c.dept_id
                  left join sys_user u on u.user_id = c.user_id
     </sql>
     <sql id="selectArdAppTaskDto">
         select a.id,
+               a.type,
                a.name,
                a.text,
                a.voice,
@@ -97,31 +96,37 @@
                c.view_time        as sub1_view_time,
                c.view_position    as sub1_view_position,
                c.clock_in_time    as sub1_clock_in_time,
-               c.view_flag        as sub1_view_flag
+               c.view_flag        as sub1_view_flag,
+               c.task_id          as sub1_task_id
         from ard_app_task a
                  left join ard_app_task_pic b on b.task_id = a.id
                  left join ard_app_task_detail c on c.task_id = a.id
     </sql>
+
     <select id="selectArdAppTaskList" parameterType="ArdAppTask" resultMap="ArdAppTaskResult">
         <include refid="selectArdAppTaskVo"/>
         <where>
-            <if test="name != null  and name != ''">and name like '%'||#{name}||'%'</if>
-            <if test="text != null  and text != ''">and text = #{text}</if>
-            <if test="voice != null  and voice != ''">and voice = #{voice}</if>
+            <if test="type != null  and type != ''">and c.type = #{type}</if>
+            <if test="name != null  and name != ''">and c.name like '%'||#{name}||'%'</if>
+            <if test="text != null  and text != ''">and c.text = #{text}</if>
+            <if test="voice != null  and voice != ''">and c.voice = #{voice}</if>
             <if test="params.beginTime != null and params.beginTime != ''"><!-- 寮�濮嬫椂闂存绱� -->
-                and create_time &gt;= to_timestamp(#{params.beginTime},'yyyy-MM-DD HH24:MI:ss')
+                and c.create_time &gt;= to_timestamp(#{params.beginTime},'yyyy-MM-DD HH24:MI:ss')
             </if>
             <if test="params.endTime != null and params.endTime != ''"><!-- 缁撴潫鏃堕棿妫�绱� -->
-                and create_time &lt;= to_timestamp(#{params.endTime},'yyyy-MM-DD HH24:MI:ss')
+                and c.create_time &lt;= to_timestamp(#{params.endTime},'yyyy-MM-DD HH24:MI:ss')
             </if>
-            <if test="userId != null  and userId != ''">and user_id = #{userId}</if>
-            <!-- 鏁版嵁鑼冨洿杩囨护 -->
-            ${params.dataScope}
+            <if test="userId != null  and userId != ''">and c.user_id = #{userId}</if>
         </where>
+        order by c.create_time desc
     </select>
     <select id="selectArdAppTaskListWithDetail" parameterType="ArdAppTask" resultMap="ArdAppTaskSubResult">
-        <include refid="selectArdAppTaskDto"/>
+        select DISTINCT(a.id)as idd,c.user_id as detail_user_id,a.* from ard_app_task a
+        LEFT JOIN ard_app_task_detail c on c.task_id=a.id
         <where>
+            <if test="id != null and id != ''">
+                and a.id = #{id}
+            </if>
             <if test="userId != null and userId != ''">
                 and c.user_id = #{userId}
             </if>
@@ -131,9 +136,8 @@
             <if test="params.endTime != null and params.endTime != ''"><!-- 缁撴潫鏃堕棿妫�绱� -->
                 and a.create_time &lt;= to_timestamp(#{params.endTime},'yyyy-MM-DD HH24:MI:ss')
             </if>
-            <!-- 鏁版嵁鑼冨洿杩囨护 -->
-            ${params.dataScope}
         </where>
+        order by a.create_time desc
     </select>
     <select id="selectArdAppTaskListWithDetailById" parameterType="ArdAppTask" resultMap="ArdAppTaskSubResult">
         <include refid="selectArdAppTaskDto"/>
@@ -152,16 +156,38 @@
             </if>
         </where>
     </select>
-
-    <select id="selectArdAppTaskById" parameterType="String" resultMap="ArdAppTaskSubResult">
+    <select id="selectArdAppTaskDetailListByTaskId" resultType="ArdAppTaskDetail">
+        select *
+        from ard_app_task_detail
+        where task_id = #{taskId}
+    </select>
+    <select id="selectArdAppTaskById" parameterType="String" resultMap="ArdAppTaskSub1Result">
         <include refid="selectArdAppTaskDto"/>
         where a.id = #{id}
     </select>
 
+    <select id="selectArdAppTaskDetailListByIdAndUserId" resultType="ArdAppTaskDetail">
+        select *
+        from ard_app_task_detail d
+        where d.task_id = #{id}
+          and d.user_id = #{detailUserId}
+    </select>
+    <select id="selectArdAppTaskPicListById" resultType="ArdAppTaskPic">
+        select *
+        from ard_app_task_pic d
+        where d.task_id = #{id}
+    </select>
+
+    <select id="selectArdAppTaskDetailUserIdsByTaskId" parameterType="String" resultType="java.lang.String">
+        select DISTINCT(user_id)
+        from ard_app_task_detail
+        where task_id = #{taskId}
+    </select>
     <insert id="insertArdAppTask" parameterType="ArdAppTask">
         insert into ard_app_task
         <trim prefix="(" suffix=")" suffixOverrides=",">
             <if test="id != null">id,</if>
+            <if test="type != null">type,</if>
             <if test="name != null">name,</if>
             <if test="text != null">text,</if>
             <if test="voice != null">voice,</if>
@@ -174,6 +200,7 @@
         </trim>
         <trim prefix="values (" suffix=")" suffixOverrides=",">
             <if test="id != null">#{id},</if>
+            <if test="type != null">#{type},</if>
             <if test="name != null">#{name},</if>
             <if test="text != null">#{text},</if>
             <if test="voice != null">#{voice},</if>
@@ -185,10 +212,10 @@
             <if test="updateTime != null">#{updateTime},</if>
         </trim>
     </insert>
-
     <update id="updateArdAppTask" parameterType="ArdAppTask">
         update ard_app_task
         <trim prefix="SET" suffixOverrides=",">
+            <if test="type != null">type = #{type},</if>
             <if test="name != null">name = #{name},</if>
             <if test="text != null">text = #{text},</if>
             <if test="voice != null">voice = #{voice},</if>
@@ -201,53 +228,45 @@
         </trim>
         where id = #{id}
     </update>
-
     <delete id="deleteArdAppTaskById" parameterType="String">
         delete
         from ard_app_task
         where id = #{id}
     </delete>
-
     <delete id="deleteArdAppTaskByIds" parameterType="String">
         delete from ard_app_task where id in
         <foreach item="id" collection="array" open="(" separator="," close=")">
             #{id}
         </foreach>
     </delete>
-
     <delete id="deleteArdAppTaskPicByTaskIds" parameterType="String">
         delete from ard_app_task_pic where task_id in
         <foreach item="taskId" collection="array" open="(" separator="," close=")">
             #{taskId}
         </foreach>
     </delete>
-
     <delete id="deleteArdAppTaskPicByTaskId" parameterType="String">
         delete
         from ard_app_task_pic
         where task_id = #{taskId}
     </delete>
-
     <insert id="batchArdAppTaskPic">
         insert into ard_app_task_pic( id, task_id, pic_url) values
         <foreach item="item" index="index" collection="list" separator=",">
             ( #{item.id}, #{item.taskId}, #{item.picUrl})
         </foreach>
     </insert>
-
     <delete id="deleteArdAppTaskDetailByTaskIds" parameterType="String">
         delete from ard_app_task_detail where task_id in
         <foreach item="taskId" collection="array" open="(" separator="," close=")">
             #{taskId}
         </foreach>
     </delete>
-
     <delete id="deleteArdAppTaskDetailByTaskId" parameterType="String">
         delete
         from ard_app_task_detail
         where task_id = #{taskId}
     </delete>
-
     <insert id="batchArdAppTaskDetail">
         insert into ard_app_task_detail( id, name, longitude, latitude, altitude, user_id, text, voice,
         task_id,status,clock_in_pic_url) values
@@ -256,7 +275,6 @@
             #{item.text}, #{item.voice}, #{item.taskId}, #{item.status}, #{item.clockInPicUrl})
         </foreach>
     </insert>
-
     <update id="updateArdAppTaskDetail" parameterType="ArdAppTaskDetail">
         update ard_app_task_detail
         <trim prefix="SET" suffixOverrides=",">
@@ -313,18 +331,17 @@
         from ard_app_task_detail c
         where c.id = #{id}
     </select>
-    <select id="selectNewArdAppTaskByUserId" parameterType="String" resultMap="ArdAppTaskSubResult">
+    <select id="selectNewArdAppTaskByUserId" parameterType="String" resultMap="ArdAppTaskSub1Result">
         <include refid="selectArdAppTaskDto"/>
         where c.user_id = #{userId} AND c.view_flag is null
         order by create_time desc limit 1
     </select>
     <select id="selectUnreadArdAppTaskCount" resultType="Integer">
-        SELECT COUNT( A.ID )
-        FROM ard_app_task
-        A LEFT JOIN ard_app_task_detail C ON C.task_id = A.ID
-        WHERE
-            C.view_time IS NULL
-          AND  C.view_flag = '1'
+        SELECT COUNT(DISTINCT A.ID)
+        FROM ard_app_task A
+                 LEFT JOIN ard_app_task_detail C ON C.task_id = A.ID
+        WHERE C.view_time IS NULL
+          AND C.view_flag = '1'
           AND C.user_id = #{userId}
     </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.3