177 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
			
		
		
	
	
			177 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
| <?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="cn.iocoder.yudao.module.course.mapper.ProcessMapper">
 | ||
| 
 | ||
|     <update id="updateProcessBatch">
 | ||
|         UPDATE drive_school_process
 | ||
|         SET exam_status = '9'
 | ||
|         WHERE
 | ||
|         user_id IN
 | ||
|         <foreach collection="userIdList" item="item" open="(" separator="," close=")">
 | ||
|             #{item}
 | ||
|         </foreach>
 | ||
|         AND course_id = #{courseId}
 | ||
|         AND `subject` = #{subject}
 | ||
|         AND coach_id = #{coachId}
 | ||
|         AND (exam_status IS NULL OR exam_status = '0')
 | ||
|         AND deleted =0
 | ||
|     </update>
 | ||
|     <update id="updateProcessExamResult">
 | ||
| 
 | ||
|     </update>
 | ||
|     <select id="selectNewMaxByUserId" resultType="cn.iocoder.yudao.module.course.entity.Process">
 | ||
|         SELECT
 | ||
|             dsp.*  FROM drive_school_process dsp
 | ||
|         WHERE
 | ||
|             dsp.user_id = #{userId}
 | ||
|         <if test="coachId != null and coachId != ''">
 | ||
|             AND dsp.coach_id=#{coachId}
 | ||
|         </if>
 | ||
|         ORDER BY  dsp.`subject` DESC, dsp.create_time DESC LIMIT 1
 | ||
|     </select>
 | ||
|     <select id="selectAllTrainTime" resultType="java.lang.Double">
 | ||
|         SELECT
 | ||
|             SUM(dsp.train_time)
 | ||
|         FROM
 | ||
|             drive_school_process dsp
 | ||
|         WHERE
 | ||
|             dsp.user_id = #{userId}
 | ||
|           AND dsp.deleted = 0
 | ||
|           AND dsp.course_id = #{courseId}
 | ||
|           AND (( dsp.`status` = '2' AND dsp.exam_status = '1' ) OR dsp.`status` = '1' )
 | ||
|     </select>
 | ||
| 
 | ||
|     <select id="pageProcess" resultType="cn.iocoder.yudao.module.course.vo.ProcessVO">
 | ||
|         SELECT
 | ||
|             dsp.*,
 | ||
|             dss.id_card AS studentIdCard,
 | ||
|             sysu.nickname AS updateName
 | ||
|         FROM drive_school_process dsp
 | ||
|         LEFT JOIN drive_school_student dss ON dss.user_id = dsp.user_id
 | ||
|         LEFT JOIN system_users sysu on sysu.id = dsp.updater
 | ||
|         <where>
 | ||
|             dsp.deleted = 0
 | ||
|             <if test="entity.coachName != null and entity.coachName != '' "> and dsp.coach_name like concat('%', #{entity.coachName}, '%')</if>
 | ||
|             <if test="entity.userName != null and entity.userName != '' "> and dsp.user_name like concat('%', #{entity.userName}, '%')</if>
 | ||
|             <if test="entity.courseName != null and entity.courseName != '' "> and dsp.name like concat('%', #{entity.courseName}, '%')</if>
 | ||
|             <if test="entity.userId != null "> and dsp.user_id = #{entity.userId}</if>
 | ||
|             <if test="entity.courseId != null and entity.courseId != '' "> and dsp.course_id = #{entity.courseId}</if>
 | ||
|             <!--<if test="entity.studentIdCard != null and entity.studentIdCard != '' "> AND RIGHT(dss.id_card, 4) = RIGHT(#{entity.studentIdCard}, 4) </if>-->
 | ||
|             <if test="entity.studentIdCard != null and entity.studentIdCard != '' ">
 | ||
|                 <choose>
 | ||
|                     <!-- 精确匹配:当输入18位时 -->
 | ||
|                     <when test="entity.studentIdCard.length() == 18">
 | ||
|                         AND dss.id_card = #{entity.studentIdCard}
 | ||
|                     </when>
 | ||
|                     <!-- 后4位匹配:当输入正好4位时 -->
 | ||
|                     <when test="entity.studentIdCard.length() == 4">
 | ||
|                         AND RIGHT(dss.id_card, 4) = #{entity.studentIdCard}
 | ||
|                     </when>
 | ||
|                     <!-- 模糊搜索:当输入大于4位但不足18位时 -->
 | ||
|                     <otherwise>
 | ||
|                         AND dss.id_card LIKE concat('%', #{entity.studentIdCard}, '%')
 | ||
|                     </otherwise>
 | ||
|                 </choose>
 | ||
|             </if>
 | ||
|         </where>
 | ||
|         ORDER BY
 | ||
|         (CASE
 | ||
|         WHEN dsp.exam_status = '1' AND dsp.finance_pass IS NULL THEN 1  -- 优先级最高
 | ||
|         WHEN dsp.exam_status = '9'  THEN 2
 | ||
|         WHEN dsp.status = '1'  THEN 2
 | ||
|         ELSE 4
 | ||
|         END),
 | ||
|         dsp.create_time DESC; -- 再按创建时间降序
 | ||
|     </select>
 | ||
| 
 | ||
|     <select id="pageProcessNew" resultType="cn.iocoder.yudao.module.course.vo.ProcessVO">
 | ||
|         SELECT
 | ||
|         dsp.*,
 | ||
|         dss.id_card AS studentIdCard,
 | ||
|         sysu.nickname AS updateName
 | ||
|         FROM drive_school_process dsp
 | ||
|         LEFT JOIN drive_school_student dss ON dss.user_id = dsp.user_id
 | ||
|         LEFT JOIN system_users sysu on sysu.id = dsp.updater
 | ||
|         <where>
 | ||
|             dsp.deleted = 0 AND dsp.subject in (2,3)
 | ||
|             <if test="entity.coachName != null and entity.coachName != '' "> and dsp.coach_name like concat('%', #{entity.coachName}, '%')</if>
 | ||
|             <if test="entity.userName != null and entity.userName != '' "> and dsp.user_name like concat('%', #{entity.userName}, '%')</if>
 | ||
|             <if test="entity.courseName != null and entity.courseName != '' "> and dsp.name like concat('%', #{entity.courseName}, '%')</if>
 | ||
|             <if test="entity.userId != null "> and dsp.user_id = #{entity.userId}</if>
 | ||
|             <if test="entity.courseId != null and entity.courseId != '' "> and dsp.course_id = #{entity.courseId}</if>
 | ||
|             <if test="entity.examStatus != null  ">and dsp.exam_status = #{entity.examStatus}</if>
 | ||
|             <choose>
 | ||
|                 <when test="entity.financePass == true">
 | ||
|                     AND dsp.finance_pass = 1
 | ||
|                 </when>
 | ||
|                 <when test="entity.financePass == false">
 | ||
|                     AND dsp.finance_pass = 0
 | ||
|                 </when>
 | ||
|                 <when test="entity.financePass == null">
 | ||
|                     AND dsp.finance_pass IS NULL
 | ||
|                 </when>
 | ||
|             </choose>
 | ||
|             <if test="entity.studentIdCard != null and entity.studentIdCard != '' ">
 | ||
|                 <choose>
 | ||
|                     <!-- 精确匹配:当输入18位时 -->
 | ||
|                     <when test="entity.studentIdCard.length() == 18">
 | ||
|                         AND dss.id_card = #{entity.studentIdCard}
 | ||
|                     </when>
 | ||
|                     <!-- 后4位匹配:当输入正好4位时 -->
 | ||
|                     <when test="entity.studentIdCard.length() == 4">
 | ||
|                         AND RIGHT(dss.id_card, 4) = #{entity.studentIdCard}
 | ||
|                     </when>
 | ||
|                     <!-- 模糊搜索:当输入大于4位但不足18位时 -->
 | ||
|                     <otherwise>
 | ||
|                         AND dss.id_card LIKE concat('%', #{entity.studentIdCard}, '%')
 | ||
|                     </otherwise>
 | ||
|                 </choose>
 | ||
|             </if>
 | ||
|         </where>
 | ||
|         ORDER BY
 | ||
|         (CASE
 | ||
|         WHEN dsp.exam_status = '1' AND dsp.finance_pass IS NULL THEN 1  -- 优先级最高
 | ||
|         WHEN dsp.exam_status = '9'  THEN 2
 | ||
|         WHEN dsp.status = '1'  THEN 2
 | ||
|         ELSE 4
 | ||
|         END),
 | ||
|         dsp.update_time DESC; -- 再按创建时间降序
 | ||
|     </select>
 | ||
| 
 | ||
|     <select id="getProcessList" resultType="cn.iocoder.yudao.module.course.entity.Process">
 | ||
|         SELECT
 | ||
|             *
 | ||
|         FROM
 | ||
|             drive_school_process
 | ||
|         WHERE
 | ||
|             user_id = #{userId}
 | ||
|           AND deleted = 0
 | ||
|           <if test="courseId!= null and courseId!= '' ">
 | ||
|               AND course_id = #{courseId}
 | ||
|           </if>
 | ||
|     </select>
 | ||
| 
 | ||
|     <select id="getProcessAndBatch" resultType="cn.iocoder.yudao.module.course.vo.ProcessAndExamBatchVO">
 | ||
|         SELECT
 | ||
|             dseb.start_time AS startTime,
 | ||
|             dseb.end_time AS endTime,
 | ||
|             dseb.addr_id AS addrId,
 | ||
|             dseb.addr AS addr,
 | ||
|             dseb.trans_way AS transWay,
 | ||
|             dseb.creator AS creator,
 | ||
|             dseb.id AS batchId,
 | ||
|             dseb.updater AS updater,
 | ||
|             dsebi.id AS batchItemId
 | ||
|         from drive_school_exam_batch dseb
 | ||
|                  left join drive_school_exam_batch_item dsebi ON dseb.id = dsebi.batch_id
 | ||
|         WHERE dseb.course_id = #{courseId}
 | ||
|           AND dseb.coach_id = #{coachId}
 | ||
|           AND dseb.subject = #{subject}
 | ||
|           AND dsebi.fraction = #{fraction}
 | ||
|           AND dsebi.user_id = #{userId}
 | ||
|         ORDER BY dseb.update_time DESC LIMIT 1
 | ||
|     </select>
 | ||
| </mapper>
 |