| 
									
										
										
										
											2025-01-18 11:22:16 +08:00
										 |  |  |  | <?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.base.mapper.DlDriveSchoolStudentMapper"> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!--
 | 
					
						
							|  |  |  |  |         一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。 | 
					
						
							|  |  |  |  |         无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。 | 
					
						
							|  |  |  |  |         代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。 | 
					
						
							|  |  |  |  |         文档可见:https://www.iocoder.cn/MyBatis/x-plugins/ | 
					
						
							|  |  |  |  |      --> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <select id="queryListPage" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							| 
									
										
										
										
											2025-04-28 18:18:42 +08:00
										 |  |  |  |         main.*, | 
					
						
							|  |  |  |  |         dsco.coach_user_name AS coachName | 
					
						
							| 
									
										
										
										
											2025-01-18 11:22:16 +08:00
										 |  |  |  |         FROM | 
					
						
							|  |  |  |  |         drive_school_student main | 
					
						
							| 
									
										
										
										
											2025-04-28 18:18:42 +08:00
										 |  |  |  |         LEFT JOIN drive_school_course_order dsco ON main.user_id = dsco.user_id | 
					
						
							| 
									
										
										
										
											2025-01-18 11:22:16 +08:00
										 |  |  |  |         <where> | 
					
						
							|  |  |  |  |             main.deleted = 0 | 
					
						
							|  |  |  |  |             <if test="entity.name != null  and entity.name != ''">and main.name like concat('%', #{entity.name}, '%')</if> | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |             <if test="entity.phone != null  and entity.phone != ''">and main.phone = #{entity.phone}</if> | 
					
						
							|  |  |  |  |             <if test="entity.idCard != null  and entity.idCard != ''">and main.id_card like concat('%', #{entity.idCard}, '%')</if> | 
					
						
							| 
									
										
										
										
											2025-05-28 17:14:39 +08:00
										 |  |  |  |             <if test="entity.source != null  and entity.source != ''">and main.source = #{entity.source}</if> | 
					
						
							| 
									
										
										
										
											2025-01-18 11:22:16 +08:00
										 |  |  |  |         </where> | 
					
						
							| 
									
										
										
										
											2025-05-10 16:35:42 +08:00
										 |  |  |  |         GROUP BY main.user_id | 
					
						
							| 
									
										
										
										
											2025-01-18 11:22:16 +08:00
										 |  |  |  |         order by main.create_time desc | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-01-21 00:12:53 +08:00
										 |  |  |  |     <select id="selectCanExamStudentList" | 
					
						
							|  |  |  |  |             resultType="cn.iocoder.yudao.module.base.entity.DlDriveSchoolStudent"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |             dss.* | 
					
						
							|  |  |  |  |         FROM | 
					
						
							|  |  |  |  |             drive_school_process dsp | 
					
						
							|  |  |  |  |                 LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id | 
					
						
							|  |  |  |  |                 AND dss.deleted = 0 | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |             dsp.deleted = 0 | 
					
						
							|  |  |  |  |             AND dsp.coach_id = #{coachId} | 
					
						
							|  |  |  |  |           AND dsp.course_id = #{courseId} | 
					
						
							|  |  |  |  |           AND dsp.`subject` = #{subject} | 
					
						
							| 
									
										
										
										
											2025-01-21 14:46:26 +08:00
										 |  |  |  |           <if test="userName!=null and userName!=''"> | 
					
						
							|  |  |  |  |               AND dsp.user_name LIKE CONCAT('%',#{userName},'%') | 
					
						
							|  |  |  |  |           </if> | 
					
						
							| 
									
										
										
										
											2025-01-21 00:12:53 +08:00
										 |  |  |  |           AND dsp.`status` = '1' | 
					
						
							|  |  |  |  |           AND dsp.exam_status IS NULL | 
					
						
							|  |  |  |  |         GROUP BY | 
					
						
							|  |  |  |  |             dss.id | 
					
						
							|  |  |  |  |         ORDER BY | 
					
						
							|  |  |  |  |             dss.create_time DESC | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-06-04 14:23:49 +08:00
										 |  |  |  |       <select id="pageStaffStudent" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStaffVO"> | 
					
						
							|  |  |  |  |           SELECT | 
					
						
							|  |  |  |  |           main.id AS id, | 
					
						
							|  |  |  |  |           main.NAME AS NAME, | 
					
						
							|  |  |  |  |           main.type AS type, | 
					
						
							|  |  |  |  |           main.avatar AS avatar, | 
					
						
							|  |  |  |  |           main.phone AS phone, | 
					
						
							|  |  |  |  |           main.user_id AS userId, | 
					
						
							|  |  |  |  |           dsco.course_type, | 
					
						
							| 
									
										
										
										
											2025-06-23 17:34:00 +08:00
										 |  |  |  |           dsp.`subject`, | 
					
						
							|  |  |  |  |           dsco.course_name, | 
					
						
							|  |  |  |  |           dsco.payment_status, | 
					
						
							|  |  |  |  |           dsco.cashier_confirm, | 
					
						
							|  |  |  |  |           dsco.pay_type, | 
					
						
							|  |  |  |  |           dsco.pay_channel, | 
					
						
							|  |  |  |  |           dsco.cashier_confirm_remark, | 
					
						
							|  |  |  |  |           dsco.reserve_money, | 
					
						
							|  |  |  |  |           dsco.rest_money, | 
					
						
							|  |  |  |  |           dsco.if_end, | 
					
						
							|  |  |  |  |           dsco.create_time AS enrollTime, | 
					
						
							|  |  |  |  |           dsco.user_no AS studentIdCard | 
					
						
							| 
									
										
										
										
											2025-06-04 14:23:49 +08:00
										 |  |  |  |           FROM | 
					
						
							|  |  |  |  |           drive_school_student main | 
					
						
							|  |  |  |  |           LEFT JOIN drive_school_course_order dsco ON main.user_id = dsco.user_id | 
					
						
							|  |  |  |  |           AND dsco.deleted = 0 | 
					
						
							|  |  |  |  |           AND dsco.payment_status IN ( '2', '3', '4', '5' ) | 
					
						
							|  |  |  |  |           AND dsco.if_end = 0 | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-04 14:23:49 +08:00
										 |  |  |  |           LEFT JOIN drive_school_process dsp ON main.user_id = dsp.user_id | 
					
						
							|  |  |  |  |           AND dsco.course_id = dsp.course_id | 
					
						
							|  |  |  |  |           AND dsp.`status` = '1' | 
					
						
							|  |  |  |  |           WHERE | 
					
						
							|  |  |  |  |           main.deleted = 0 AND dsco.is_sign = 1 | 
					
						
							|  |  |  |  |           <if test="entity.coachId != null and entity.coachId != ''"> | 
					
						
							|  |  |  |  |               AND dsp.coach_id = #{entity.coachId} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.sourceCoachId != null and entity.sourceCoachId != ''"> | 
					
						
							|  |  |  |  |               AND main.source_user_id = #{entity.sourceCoachId} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.name!=null and entity.name!=''"> | 
					
						
							|  |  |  |  |               AND main.name LIKE CONCAT('%',#{entity.name},'%') | 
					
						
							|  |  |  |  |           </if> | 
					
						
							| 
									
										
										
										
											2025-06-27 15:08:32 +08:00
										 |  |  |  |           <if test="entity.workName!=null and entity.workName!=''"> | 
					
						
							|  |  |  |  |               AND main.work_name = #{entity.workName} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							| 
									
										
										
										
											2025-06-04 14:23:49 +08:00
										 |  |  |  |           <if test="entity.courseType != null and entity.courseType != ''"> | 
					
						
							|  |  |  |  |               AND dsco.course_type = #{entity.courseType} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.subject != null and entity.subject != ''"> | 
					
						
							|  |  |  |  |               AND dsp.subject = #{entity.subject} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.startTime!=null and entity.startTime!=''"> | 
					
						
							|  |  |  |  |               AND dsco.create_time >= #{entity.startTime} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.endTime!=null and entity.endTime!=''"> | 
					
						
							|  |  |  |  |               AND dsco.create_time <= #{entity.endTime} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.source!=null and entity.source!=''"> | 
					
						
							|  |  |  |  |               AND main.source = #{entity.source} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.examStatus!=null and entity.examStatus!=''"> | 
					
						
							|  |  |  |  |               AND dsp.exam_status = #{entity.examStatus} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.rangeTime!=null"> | 
					
						
							|  |  |  |  |               AND dsco.create_time BETWEEN #{entity.rangeTime[0]} AND #{entity.rangeTime[1]} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.address!=null and entity.address!=''"> | 
					
						
							|  |  |  |  |               AND main.address LIKE CONCAT('%',#{entity.address},'%') | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.age!=null and entity.age!=''"> | 
					
						
							|  |  |  |  |               AND main.id_card IS NOT NULL | 
					
						
							|  |  |  |  |               AND TIMESTAMPDIFF(YEAR, STR_TO_DATE(SUBSTRING(main.id_card, 7, 8), '%Y%m%d'), CURDATE()) BETWEEN #{entity.age[0]} AND #{entity.age[1]} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           <if test="entity.passDays!=null and entity.passDays!=''"> | 
					
						
							|  |  |  |  |               AND dsco.pass_time IS NOT NULL | 
					
						
							|  |  |  |  |              AND TIMESTAMPDIFF(DAY, dsco.create_time, dsco.pass_time)  = #{entity.passDays} | 
					
						
							|  |  |  |  |           </if> | 
					
						
							|  |  |  |  |           GROUP BY | 
					
						
							|  |  |  |  |           main.id | 
					
						
							|  |  |  |  |           <choose> | 
					
						
							|  |  |  |  |               <when test="entity.sort=='asc'"> | 
					
						
							|  |  |  |  |                   ORDER BY | 
					
						
							|  |  |  |  |                   dsco.create_time ASC | 
					
						
							|  |  |  |  |               </when> | 
					
						
							|  |  |  |  |               <otherwise> | 
					
						
							|  |  |  |  |                   ORDER BY | 
					
						
							|  |  |  |  |                   dsco.create_time DESC | 
					
						
							|  |  |  |  |               </otherwise> | 
					
						
							|  |  |  |  |           </choose> | 
					
						
							|  |  |  |  |       </select> | 
					
						
							| 
									
										
										
										
											2025-02-13 17:38:07 +08:00
										 |  |  |  |     <select id="selectByCoachId" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							| 
									
										
										
										
											2025-04-18 17:45:20 +08:00
										 |  |  |  |         temp.* | 
					
						
							| 
									
										
										
										
											2025-02-13 17:38:07 +08:00
										 |  |  |  |         FROM | 
					
						
							| 
									
										
										
										
											2025-04-18 17:45:20 +08:00
										 |  |  |  |         ( | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         dss.*,dsco.id AS orderId,dsco.course_name,dsp.coach_id,dsp.course_id | 
					
						
							|  |  |  |  |         FROM | 
					
						
							|  |  |  |  |         drive_school_process dsp | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_course_order dsco ON dsp.user_id = dsco.user_id AND dsp.course_id = dsco.course_id | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         dsp.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.if_end = 0 | 
					
						
							|  |  |  |  |         AND dsco.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsp.coach_id = #{entity.coachId} | 
					
						
							|  |  |  |  |         <if test="entity.name != null and entity.name!=''"> | 
					
						
							|  |  |  |  |             AND dss.`name` LIKE CONCAT('%',#{entity.name},'%') | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="entity.startTime!=null and entity.startTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time >= #{entity.startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="entity.endTime!=null and entity.endTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time <= #{entity.endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-05-28 17:14:39 +08:00
										 |  |  |  |         <if test="entity.isGrad != null and entity.isGrad == 'correct'"> | 
					
						
							|  |  |  |  |             AND dsco.grad_time IS NOT NULL | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="entity.isGrad != null and entity.isGrad == 'deny'"> | 
					
						
							|  |  |  |  |             AND dsco.grad_time IS NULL | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-04-18 17:45:20 +08:00
										 |  |  |  |         AND dss.id IS NOT NULL | 
					
						
							|  |  |  |  |         ORDER BY | 
					
						
							|  |  |  |  |         dss.create_time DESC | 
					
						
							|  |  |  |  |         ) temp | 
					
						
							| 
									
										
										
										
											2025-02-13 17:38:07 +08:00
										 |  |  |  |         GROUP BY | 
					
						
							| 
									
										
										
										
											2025-04-18 17:45:20 +08:00
										 |  |  |  |         temp.orderId | 
					
						
							| 
									
										
										
										
											2025-02-13 17:38:07 +08:00
										 |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     <select id="selectByBusinessId" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         dss.*,dsco.course_type AS courseType | 
					
						
							|  |  |  |  |         FROM | 
					
						
							|  |  |  |  |         drive_school_student dss | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_course_order dsco ON dss.user_id = dsco.user_id | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         dss.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.if_end = 0 | 
					
						
							|  |  |  |  |         AND dsco.deleted = 0 | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  | --         AND dsco.payment_status in ( '2', '3', '4', '5' ) | 
					
						
							|  |  |  |  | --         AND dsco.is_sign = 1 | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |         AND dss.id IS NOT NULL | 
					
						
							| 
									
										
										
										
											2025-06-13 16:57:34 +08:00
										 |  |  |  |         <choose> | 
					
						
							|  |  |  |  |             <when test="entity.pType == 'yg'"> | 
					
						
							|  |  |  |  |                 AND dss.source = '01' | 
					
						
							|  |  |  |  |             </when> | 
					
						
							|  |  |  |  |             <when test="entity.pType == 'ywjl'"> | 
					
						
							|  |  |  |  |                 AND dss.source = '04' | 
					
						
							|  |  |  |  |             </when> | 
					
						
							|  |  |  |  |         </choose> | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |         AND dss.source_user_id = #{entity.coachId} | 
					
						
							|  |  |  |  |         <if test="entity.name != null and entity.name!=''"> | 
					
						
							|  |  |  |  |             AND dss.`name` LIKE CONCAT('%',#{entity.name},'%') | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="entity.startTime!=null and entity.startTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time >= #{entity.startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="entity.endTime!=null and entity.endTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time <= #{entity.endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-05-27 11:49:37 +08:00
										 |  |  |  |         <if test="entity.courseType!=null and entity.courseType!=''"> | 
					
						
							|  |  |  |  |             AND dsco.course_type = #{entity.courseType} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  |         <if test="entity.isSign!=null"> | 
					
						
							|  |  |  |  |             AND dsco.is_sign = #{entity.isSign} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |         GROUP BY | 
					
						
							| 
									
										
										
										
											2025-05-27 11:49:37 +08:00
										 |  |  |  |         dss.user_id | 
					
						
							|  |  |  |  |         <choose> | 
					
						
							|  |  |  |  |             <when test="entity.sort=='asc'"> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dss.create_time ASC | 
					
						
							|  |  |  |  |             </when> | 
					
						
							|  |  |  |  |             <otherwise> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dss.create_time DESC | 
					
						
							|  |  |  |  |             </otherwise> | 
					
						
							|  |  |  |  |         </choose> | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-02-19 09:27:44 +08:00
										 |  |  |  |     <select id="selectStudentList" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |             dss.* ,SUM(dsco.reserve_money+dsco.rest_money)AS priceAmount | 
					
						
							|  |  |  |  |         FROM | 
					
						
							|  |  |  |  |             drive_school_student dss | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |                 LEFT JOIN drive_school_course_order dsco ON dss.user_id=dsco.user_id AND dsco.deleted=0 AND dsco.if_end=0 AND dsco.is_sign = 1 | 
					
						
							| 
									
										
										
										
											2025-02-19 09:27:44 +08:00
										 |  |  |  |         WHERE | 
					
						
							|  |  |  |  |             dss.deleted=0 | 
					
						
							|  |  |  |  |           AND dsco.id IS NOT NULL | 
					
						
							|  |  |  |  |         <if test="startTime!=null and startTime!=''"> | 
					
						
							|  |  |  |  |           AND dss.create_time >= #{startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime!=null and endTime!=''"> | 
					
						
							|  |  |  |  |           AND dss.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="coachId!=null and coachId!=''"> | 
					
						
							|  |  |  |  |             AND dss.source_user_id=#{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         GROUP BY dss.id | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |     <select id="selectStudentListByOrder" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT dss.*,SUM(dsco.reserve_money+dsco.rest_money)AS priceAmount | 
					
						
							|  |  |  |  |             FROM drive_school_course_order dsco | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_student dss ON dsco.user_id=dss.user_id AND dss.deleted=0 | 
					
						
							|  |  |  |  |         WHERE dsco.deleted=0 | 
					
						
							|  |  |  |  |         <if test="startTime!=null and startTime!=''"> | 
					
						
							|  |  |  |  |             AND dsco.create_time >= #{startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime!=null and endTime!=''"> | 
					
						
							|  |  |  |  |             AND dsco.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="coachId!=null and coachId!=''"> | 
					
						
							|  |  |  |  |             AND dsco.coach_id=#{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         GROUP BY dss.id | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-02-19 09:27:44 +08:00
										 |  |  |  |     <select id="selectStudentListCoach" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |         dss.*,dsco.grad_time AS orderGradTime,dsco.id AS orderId,dsco.course_type AS courseType | 
					
						
							| 
									
										
										
										
											2025-02-19 09:27:44 +08:00
										 |  |  |  |         FROM | 
					
						
							| 
									
										
										
										
											2025-04-18 17:45:20 +08:00
										 |  |  |  |         drive_school_process dsp | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_course_order dsco ON dsp.user_id = dsco.user_id AND dsp.course_id = dsco.course_id | 
					
						
							| 
									
										
										
										
											2025-02-19 09:27:44 +08:00
										 |  |  |  |         WHERE | 
					
						
							| 
									
										
										
										
											2025-04-18 17:45:20 +08:00
										 |  |  |  |         dsp.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.if_end = 0 | 
					
						
							|  |  |  |  |         AND dsco.deleted = 0 | 
					
						
							|  |  |  |  |         AND dss.id IS NOT NULL | 
					
						
							| 
									
										
										
										
											2025-02-19 09:27:44 +08:00
										 |  |  |  |         <if test="coachId != null and coachId != ''"> | 
					
						
							|  |  |  |  |             AND dsp.coach_id = #{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="startTime!=null and startTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time >= #{startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime!=null and endTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         GROUP BY | 
					
						
							| 
									
										
										
										
											2025-04-18 17:45:20 +08:00
										 |  |  |  |         dsco.id | 
					
						
							|  |  |  |  |         <!--        旧的sql--> | 
					
						
							|  |  |  |  |         <!--        SELECT--> | 
					
						
							|  |  |  |  |         <!--            dss.*--> | 
					
						
							|  |  |  |  |         <!--        FROM--> | 
					
						
							|  |  |  |  |         <!--            drive_school_process dsp--> | 
					
						
							|  |  |  |  |         <!--                LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id--> | 
					
						
							|  |  |  |  |         <!--        WHERE--> | 
					
						
							|  |  |  |  |         <!--            dsp.deleted = 0--> | 
					
						
							|  |  |  |  |         <!--          AND dss.id IS NOT NULL--> | 
					
						
							|  |  |  |  |         <!--        <if test="coachId != null and coachId != ''">--> | 
					
						
							|  |  |  |  |         <!--            AND dsp.coach_id = #{coachId}--> | 
					
						
							|  |  |  |  |         <!--        </if>--> | 
					
						
							|  |  |  |  |         <!--        <if test="startTime!=null and startTime!=''">--> | 
					
						
							|  |  |  |  |         <!--            AND dss.create_time >= #{startTime}--> | 
					
						
							|  |  |  |  |         <!--        </if>--> | 
					
						
							|  |  |  |  |         <!--        <if test="endTime!=null and endTime!=''">--> | 
					
						
							|  |  |  |  |         <!--            AND dss.create_time <= #{endTime}--> | 
					
						
							|  |  |  |  |         <!--        </if>--> | 
					
						
							|  |  |  |  |         <!--        GROUP BY--> | 
					
						
							|  |  |  |  |         <!--        dsp.id--> | 
					
						
							| 
									
										
										
										
											2025-02-19 09:27:44 +08:00
										 |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |     <select id="selectStudentListBusiness" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         dss.*,dsco.course_type AS courseType | 
					
						
							|  |  |  |  |         FROM | 
					
						
							|  |  |  |  |         drive_school_student dss | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_course_order dsco ON dss.user_id = dsco.user_id | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         dss.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.if_end = 0 | 
					
						
							|  |  |  |  |         AND dsco.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.payment_status in ( '2', '3', '4', '5' ) | 
					
						
							|  |  |  |  |         AND dsco.is_sign = 1 | 
					
						
							|  |  |  |  |         AND dss.id IS NOT NULL | 
					
						
							|  |  |  |  |           AND dss.source = '04' | 
					
						
							|  |  |  |  |         <if test="coachId != null and coachId != ''"> | 
					
						
							|  |  |  |  |             AND dss.source_user_id = #{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="startTime!=null and startTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time >= #{startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime!=null and endTime!=''"> | 
					
						
							|  |  |  |  |             AND dss.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         GROUP BY | 
					
						
							|  |  |  |  |         dsco.id | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     <select id="selectStudentListByBusiness" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentByBusinessVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         dss.*, | 
					
						
							| 
									
										
										
										
											2025-06-06 17:32:16 +08:00
										 |  |  |  |         -- 使用 MAX/MIN 取任意一个订单信息(不累加) | 
					
						
							|  |  |  |  |         MAX(dsco.course_type) AS courseType, | 
					
						
							|  |  |  |  |         MAX(dsco.course_name) AS course_name, | 
					
						
							|  |  |  |  |         MAX(dsco.payment_status) AS payment_status, | 
					
						
							|  |  |  |  |         MAX(dsco.is_sign) AS is_sign, | 
					
						
							|  |  |  |  |         MAX(dsco.reserve_money) AS reserve_money,  -- 不累加,只取一个订单的金额 | 
					
						
							|  |  |  |  |         MAX(dsco.rest_money) AS rest_money,        -- 不累加,只取一个订单的金额 | 
					
						
							|  |  |  |  |         MAX(dsco.pay_type) AS pay_type | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  |         FROM | 
					
						
							|  |  |  |  |         drive_school_student dss | 
					
						
							| 
									
										
										
										
											2025-06-06 17:32:16 +08:00
										 |  |  |  |         LEFT JOIN drive_school_course_order dsco | 
					
						
							|  |  |  |  |         ON dss.user_id = dsco.user_id | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  |         AND dsco.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.if_end = 0 | 
					
						
							| 
									
										
										
										
											2025-06-06 17:32:16 +08:00
										 |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         dss.deleted = 0 | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  |         AND dss.id IS NOT NULL | 
					
						
							|  |  |  |  |         AND dss.source = '04' | 
					
						
							|  |  |  |  |         <if test="coachId != null and coachId != ''"> | 
					
						
							|  |  |  |  |             AND dss.source_user_id = #{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-06-06 17:32:16 +08:00
										 |  |  |  |         <if test="startTime != null and startTime != ''"> | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  |             AND dss.create_time >= #{startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-06-06 17:32:16 +08:00
										 |  |  |  |         <if test="endTime != null and endTime != ''"> | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  |             AND dss.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-06-06 17:32:16 +08:00
										 |  |  |  |         <if test="isSign == 1"> | 
					
						
							|  |  |  |  |             -- 有至少一条订单已面签 | 
					
						
							|  |  |  |  |             AND dss.user_id IN ( | 
					
						
							|  |  |  |  |             SELECT user_id FROM drive_school_course_order | 
					
						
							|  |  |  |  |             WHERE is_sign = 1 AND deleted = 0 AND if_end = 0 | 
					
						
							|  |  |  |  |             GROUP BY user_id | 
					
						
							|  |  |  |  |             ) | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="isSign == 0"> | 
					
						
							|  |  |  |  |             -- 没有任何一条订单是已面签的用户 | 
					
						
							|  |  |  |  |             AND dss.user_id NOT IN ( | 
					
						
							|  |  |  |  |             SELECT user_id FROM drive_school_course_order | 
					
						
							|  |  |  |  |             WHERE is_sign = 1 AND deleted = 0 AND if_end = 0 | 
					
						
							|  |  |  |  |             GROUP BY user_id | 
					
						
							|  |  |  |  |             ) | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         GROUP BY dss.user_id  -- 按学生分组,确保每个学生只出现一次 | 
					
						
							| 
									
										
										
										
											2025-06-13 16:57:34 +08:00
										 |  |  |  |     </select> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <select id="selectIndexInfoByWorking" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentByBusinessVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         dss.*, | 
					
						
							|  |  |  |  |         -- 使用 MAX/MIN 取任意一个订单信息(不累加) | 
					
						
							|  |  |  |  |         MAX(dsco.course_type) AS courseType, | 
					
						
							|  |  |  |  |         MAX(dsco.course_name) AS course_name, | 
					
						
							|  |  |  |  |         MAX(dsco.payment_status) AS payment_status, | 
					
						
							|  |  |  |  |         MAX(dsco.is_sign) AS is_sign, | 
					
						
							|  |  |  |  |         MAX(dsco.reserve_money) AS reserve_money,  -- 不累加,只取一个订单的金额 | 
					
						
							|  |  |  |  |         MAX(dsco.rest_money) AS rest_money,        -- 不累加,只取一个订单的金额 | 
					
						
							|  |  |  |  |         MAX(dsco.pay_type) AS pay_type | 
					
						
							|  |  |  |  |         FROM | 
					
						
							|  |  |  |  |         drive_school_student dss | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_course_order dsco | 
					
						
							|  |  |  |  |         ON dss.user_id = dsco.user_id | 
					
						
							|  |  |  |  |         AND dsco.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.if_end = 0 | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         dss.deleted = 0 | 
					
						
							|  |  |  |  |         AND dss.id IS NOT NULL | 
					
						
							|  |  |  |  |         AND dss.source = '01' | 
					
						
							|  |  |  |  |         <if test="coachId != null and coachId != ''"> | 
					
						
							|  |  |  |  |             AND dss.source_user_id = #{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="startTime != null and startTime != ''"> | 
					
						
							|  |  |  |  |             AND dss.create_time >= #{startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime != null and endTime != ''"> | 
					
						
							|  |  |  |  |             AND dss.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="isSign == 1"> | 
					
						
							|  |  |  |  |             -- 有至少一条订单已面签 | 
					
						
							|  |  |  |  |             AND dss.user_id IN ( | 
					
						
							|  |  |  |  |             SELECT user_id FROM drive_school_course_order | 
					
						
							|  |  |  |  |             WHERE is_sign = 1 AND deleted = 0 AND if_end = 0 | 
					
						
							|  |  |  |  |             GROUP BY user_id | 
					
						
							|  |  |  |  |             ) | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="isSign == 0"> | 
					
						
							|  |  |  |  |             -- 没有任何一条订单是已面签的用户 | 
					
						
							|  |  |  |  |             AND dss.user_id NOT IN ( | 
					
						
							|  |  |  |  |             SELECT user_id FROM drive_school_course_order | 
					
						
							|  |  |  |  |             WHERE is_sign = 1 AND deleted = 0 AND if_end = 0 | 
					
						
							|  |  |  |  |             GROUP BY user_id | 
					
						
							|  |  |  |  |             ) | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         GROUP BY dss.user_id  -- 按学生分组,确保每个学生只出现一次 | 
					
						
							| 
									
										
										
										
											2025-06-03 16:22:52 +08:00
										 |  |  |  |     </select> | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-19 16:26:12 +08:00
										 |  |  |  |     <select id="selectTrainStudent" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							| 
									
										
										
										
											2025-02-21 10:30:09 +08:00
										 |  |  |  |             dss.*,dsc.type AS courseType,dst.subject | 
					
						
							| 
									
										
										
										
											2025-02-19 16:26:12 +08:00
										 |  |  |  |         FROM | 
					
						
							|  |  |  |  |             drive_school_student dss | 
					
						
							| 
									
										
										
										
											2025-02-21 10:30:09 +08:00
										 |  |  |  |                 LEFT JOIN drive_school_train dst ON dss.user_id = dst.user_id AND dst.deleted = 0 | 
					
						
							|  |  |  |  |                 LEFT JOIN drive_school_course dsc ON dst.course_id = dsc.id | 
					
						
							| 
									
										
										
										
											2025-02-19 16:26:12 +08:00
										 |  |  |  |         WHERE | 
					
						
							|  |  |  |  |             dst.id IS NOT NULL | 
					
						
							|  |  |  |  |           AND dss.deleted = 0 | 
					
						
							|  |  |  |  |         <if test="coachId != null and coachId != ''"> | 
					
						
							|  |  |  |  |             AND dst.coach_id = #{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-02-21 10:30:09 +08:00
										 |  |  |  |         <if test="courseType != null and courseType != ''"> | 
					
						
							|  |  |  |  |             AND dsc.type = #{courseType} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="subject != null and subject != ''"> | 
					
						
							|  |  |  |  |             AND dst.subject = #{subject} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-02-20 09:30:38 +08:00
										 |  |  |  |         <if test="searchValue != null and searchValue != ''"> | 
					
						
							|  |  |  |  |             AND dss.name LIKE CONCAT('%',#{searchValue},'%') | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-02-19 16:26:12 +08:00
										 |  |  |  |         <if test="startTime!=null and startTime!=''"> | 
					
						
							|  |  |  |  |             AND dst.create_time >= #{startTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime!=null and endTime!=''"> | 
					
						
							|  |  |  |  |             AND dst.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         GROUP BY | 
					
						
							|  |  |  |  |             dss.id | 
					
						
							| 
									
										
										
										
											2025-02-21 10:30:09 +08:00
										 |  |  |  |         <choose> | 
					
						
							|  |  |  |  |             <when test="sort=='asc'"> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dst.create_time ASC | 
					
						
							|  |  |  |  |             </when> | 
					
						
							|  |  |  |  |             <otherwise> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dst.create_time DESC | 
					
						
							|  |  |  |  |             </otherwise> | 
					
						
							|  |  |  |  |         </choose> | 
					
						
							| 
									
										
										
										
											2025-02-19 16:26:12 +08:00
										 |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-02-19 17:29:51 +08:00
										 |  |  |  |     <select id="indexGetTrainList" resultType="cn.iocoder.yudao.module.base.vo.StudentCountVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |         c.id, | 
					
						
							| 
									
										
										
										
											2025-06-23 17:34:00 +08:00
										 |  |  |  |         c.user_id AS coachId, | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |         c.image AS image, | 
					
						
							|  |  |  |  |         c.NAME AS coachName, | 
					
						
							|  |  |  |  |         c.car_id AS carId, | 
					
						
							|  |  |  |  |         c.user_id AS userId, | 
					
						
							|  |  |  |  |         COUNT(DISTINCT s.user_id) AS totalNum, | 
					
						
							|  |  |  |  |         COUNT(DISTINCT CASE WHEN o.course_type = 'C1' THEN o.user_id END) AS c1Num, | 
					
						
							| 
									
										
										
										
											2025-05-10 16:35:42 +08:00
										 |  |  |  |         COUNT(DISTINCT CASE WHEN o.course_type = 'C2' THEN o.user_id END) AS c2Num, | 
					
						
							|  |  |  |  |         COUNT(DISTINCT o.user_id) AS timeTotal | 
					
						
							| 
									
										
										
										
											2025-02-19 17:29:51 +08:00
										 |  |  |  |         FROM | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |         drive_school_coach c | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_student s ON c.user_id = s.source_user_id AND s.deleted=0 | 
					
						
							| 
									
										
										
										
											2025-02-19 18:12:05 +08:00
										 |  |  |  |         <if test="type != null and type != ''"> | 
					
						
							|  |  |  |  |             AND s.source = #{type} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |         LEFT JOIN drive_school_course_order o ON s.user_id = o.user_id AND o.payment_status > 1 AND o.deleted=0 AND o.is_sign = 1 AND o.if_end = 0 | 
					
						
							| 
									
										
										
										
											2025-02-19 18:12:05 +08:00
										 |  |  |  |         <if test="startTime != null and startTime != ''"> | 
					
						
							| 
									
										
										
										
											2025-02-27 17:34:02 +08:00
										 |  |  |  |             AND o.create_time >= #{startTime} | 
					
						
							| 
									
										
										
										
											2025-02-19 18:12:05 +08:00
										 |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime != null and endTime != ''"> | 
					
						
							|  |  |  |  |             AND o.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-02-19 17:29:51 +08:00
										 |  |  |  |         WHERE | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |         c.deleted = 0 | 
					
						
							|  |  |  |  |         <if test="coachId != null and coachId != ''"> | 
					
						
							|  |  |  |  |             AND c.user_id = #{coachId} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="type != null and type != ''"> | 
					
						
							|  |  |  |  |             <choose> | 
					
						
							|  |  |  |  |                 <when test="type=='01'"> | 
					
						
							|  |  |  |  |                     AND c.type='yg' | 
					
						
							|  |  |  |  |                 </when> | 
					
						
							|  |  |  |  |                 <when test="type=='02'"> | 
					
						
							|  |  |  |  |                     AND c.type='jl' | 
					
						
							|  |  |  |  |                 </when> | 
					
						
							| 
									
										
										
										
											2025-06-06 17:32:16 +08:00
										 |  |  |  |                 <when test="type=='04'"> | 
					
						
							|  |  |  |  |                     AND c.type='ywjl' | 
					
						
							|  |  |  |  |                 </when> | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |             </choose> | 
					
						
							|  |  |  |  |         </if> | 
					
						
							| 
									
										
										
										
											2025-02-19 17:29:51 +08:00
										 |  |  |  |         GROUP BY | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |         c.id | 
					
						
							| 
									
										
										
										
											2025-02-19 17:29:51 +08:00
										 |  |  |  |         ORDER BY | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  |         totalNum DESC | 
					
						
							| 
									
										
										
										
											2025-02-19 17:29:51 +08:00
										 |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-04-29 16:06:22 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-21 10:27:25 +08:00
										 |  |  |  |     <select id="indexGetFormList" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStaffVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |             main.id AS id, | 
					
						
							|  |  |  |  |             main.avatar AS avatar, | 
					
						
							|  |  |  |  |             main.name AS name, | 
					
						
							|  |  |  |  |             main.phone AS phone, | 
					
						
							| 
									
										
										
										
											2025-02-27 17:34:02 +08:00
										 |  |  |  |             main.user_id AS userId, | 
					
						
							| 
									
										
										
										
											2025-02-21 10:27:25 +08:00
										 |  |  |  |             dsco.course_type AS courseType | 
					
						
							|  |  |  |  |         FROM | 
					
						
							|  |  |  |  |             drive_school_student main | 
					
						
							|  |  |  |  |                 LEFT JOIN drive_school_course_order dsco ON main.user_id = dsco.user_id | 
					
						
							|  |  |  |  |         WHERE main.deleted = 0 | 
					
						
							|  |  |  |  |           AND dsco.payment_status > 1 | 
					
						
							| 
									
										
										
										
											2025-02-27 17:34:02 +08:00
										 |  |  |  |         AND main.source='03' | 
					
						
							| 
									
										
										
										
											2025-02-21 10:27:25 +08:00
										 |  |  |  |         <if test="startTime != null and startTime != ''"> | 
					
						
							| 
									
										
										
										
											2025-02-27 17:34:02 +08:00
										 |  |  |  |             AND dsco.create_time >= #{startTime} | 
					
						
							| 
									
										
										
										
											2025-02-21 10:27:25 +08:00
										 |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="endTime != null and endTime != ''"> | 
					
						
							|  |  |  |  |             AND dsco.create_time <= #{endTime} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-06-18 17:24:30 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-25 17:10:29 +08:00
										 |  |  |  |     <select id="selectStudentListCount" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStaffVO"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         main.id AS id, | 
					
						
							| 
									
										
										
										
											2025-06-08 15:57:00 +08:00
										 |  |  |  |         dsco.course_type, | 
					
						
							|  |  |  |  |         dsco.grad_time, | 
					
						
							|  |  |  |  |         dsco.pass_time | 
					
						
							| 
									
										
										
										
											2025-02-25 17:10:29 +08:00
										 |  |  |  |         FROM | 
					
						
							|  |  |  |  |         drive_school_student main | 
					
						
							|  |  |  |  |         LEFT JOIN drive_school_course_order dsco ON main.user_id = dsco.user_id | 
					
						
							|  |  |  |  |         AND dsco.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsco.payment_status IN ( '2', '3', '4', '5' ) | 
					
						
							|  |  |  |  |         AND dsco.if_end = 0 | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-25 17:10:29 +08:00
										 |  |  |  |         LEFT JOIN drive_school_process dsp ON main.user_id = dsp.user_id | 
					
						
							|  |  |  |  |         AND dsco.course_id = dsp.course_id | 
					
						
							|  |  |  |  |         AND dsp.`status` = '1' | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         main.deleted = 0 | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  |           AND dsco.is_sign = 1 | 
					
						
							| 
									
										
										
										
											2025-02-25 17:10:29 +08:00
										 |  |  |  |         GROUP BY | 
					
						
							|  |  |  |  |         main.id | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-02-27 17:34:02 +08:00
										 |  |  |  |     <select id="indexCusStudentList" resultType="cn.iocoder.yudao.module.base.vo.StudentCountVO"> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-05-26 15:28:27 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     <select id="getAll" resultType="cn.iocoder.yudao.module.base.vo.DriveSchoolStudentExportVo"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         name, | 
					
						
							|  |  |  |  |         age, | 
					
						
							|  |  |  |  |         CASE sex WHEN '0' THEN '男' WHEN '1' THEN '女' ELSE '未知' END AS sex, | 
					
						
							|  |  |  |  |         phone, | 
					
						
							|  |  |  |  |         CASE source | 
					
						
							|  |  |  |  |         WHEN '01' THEN '驾校统招' | 
					
						
							|  |  |  |  |         WHEN '02' THEN '教练自招' | 
					
						
							|  |  |  |  |         WHEN '03' THEN '自来客户' | 
					
						
							|  |  |  |  |         ELSE source | 
					
						
							|  |  |  |  |         END AS source, | 
					
						
							|  |  |  |  |         id_card AS idCard, | 
					
						
							|  |  |  |  |         work_name AS workName, | 
					
						
							|  |  |  |  |         regist_address AS registAddress, | 
					
						
							|  |  |  |  |         address, | 
					
						
							|  |  |  |  |         remark, | 
					
						
							|  |  |  |  |         driving_student_code AS drivingStudentCode, | 
					
						
							|  |  |  |  |         DATE_FORMAT(create_time, '%Y-%m-%d') AS createTimeStr | 
					
						
							|  |  |  |  |         FROM drive_school_student | 
					
						
							|  |  |  |  |         <where> | 
					
						
							|  |  |  |  |             deleted = 0 | 
					
						
							|  |  |  |  |             <if test="entity.name != null and entity.name != ''"> | 
					
						
							|  |  |  |  |                 AND name LIKE CONCAT('%', #{entity.name}, '%') | 
					
						
							|  |  |  |  |             </if> | 
					
						
							|  |  |  |  |             <if test="entity.phone != null and entity.phone != ''"> | 
					
						
							|  |  |  |  |                 AND phone = #{entity.phone} | 
					
						
							|  |  |  |  |             </if> | 
					
						
							|  |  |  |  |             <if test="entity.idCard != null and entity.idCard != ''"> | 
					
						
							|  |  |  |  |                 AND id_card LIKE CONCAT('%', #{entity.idCard}, '%') | 
					
						
							|  |  |  |  |             </if> | 
					
						
							|  |  |  |  |         </where> | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-06-18 17:24:30 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <!--    获取教练已经毕业的学员列表--> | 
					
						
							|  |  |  |  |     <select id="getGradStudentByCourseType" resultType="cn.iocoder.yudao.module.base.entity.DlDriveSchoolStudent"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         dss.* | 
					
						
							|  |  |  |  |         FROM drive_school_process dsp | 
					
						
							|  |  |  |  |         INNER JOIN drive_school_coach dsc ON dsc.user_id = dsp.coach_id AND dsc.deleted = 0 | 
					
						
							|  |  |  |  |         INNER JOIN drive_school_student dss ON dsp.user_id = dss.user_id AND dss.deleted = 0 | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         dsp.subject = 3 | 
					
						
							|  |  |  |  |         AND dsp.exam_status = '1' | 
					
						
							|  |  |  |  |         AND dsp.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsc.user_id = #{coachId} | 
					
						
							|  |  |  |  |         <if test="courseType != null and courseType != ''"> | 
					
						
							|  |  |  |  |             AND dsp.course_type = #{courseType} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="name != null and name != ''"> | 
					
						
							|  |  |  |  |             AND dss.name LIKE CONCAT('%', #{name}, '%') | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <choose> | 
					
						
							|  |  |  |  |             <when test="sort=='asc'"> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dss.create_time ASC | 
					
						
							|  |  |  |  |             </when> | 
					
						
							|  |  |  |  |             <otherwise> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dss.create_time DESC | 
					
						
							|  |  |  |  |             </otherwise> | 
					
						
							|  |  |  |  |         </choose> | 
					
						
							|  |  |  |  |     </select> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!--    获取教练已经毕业的学员列表--> | 
					
						
							|  |  |  |  |     <select id="getNoGradStudentByCourseType" resultType="cn.iocoder.yudao.module.base.entity.DlDriveSchoolStudent"> | 
					
						
							|  |  |  |  |         SELECT | 
					
						
							|  |  |  |  |         dss.* | 
					
						
							|  |  |  |  |         FROM drive_school_process dsp | 
					
						
							|  |  |  |  |         INNER JOIN drive_school_coach dsc ON dsc.user_id = dsp.coach_id AND dsc.deleted = 0 | 
					
						
							|  |  |  |  |         INNER JOIN drive_school_student dss ON dsp.user_id = dss.user_id AND dss.deleted = 0 | 
					
						
							|  |  |  |  |         WHERE | 
					
						
							|  |  |  |  |         dsp.subject = 3 | 
					
						
							|  |  |  |  |         AND (dsp.exam_status != '1' OR dsp.exam_status IS NULL) | 
					
						
							|  |  |  |  |         AND dsp.deleted = 0 | 
					
						
							|  |  |  |  |         AND dsc.user_id = #{coachId} | 
					
						
							|  |  |  |  |         <if test="courseType != null and courseType != ''"> | 
					
						
							|  |  |  |  |             AND dsp.course_type = #{courseType} | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <if test="name != null and name != ''"> | 
					
						
							|  |  |  |  |             AND dss.name LIKE CONCAT('%', #{name}, '%') | 
					
						
							|  |  |  |  |         </if> | 
					
						
							|  |  |  |  |         <choose> | 
					
						
							|  |  |  |  |             <when test="sort=='asc'"> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dss.create_time ASC | 
					
						
							|  |  |  |  |             </when> | 
					
						
							|  |  |  |  |             <otherwise> | 
					
						
							|  |  |  |  |                 ORDER BY | 
					
						
							|  |  |  |  |                 dss.create_time DESC | 
					
						
							|  |  |  |  |             </otherwise> | 
					
						
							|  |  |  |  |         </choose> | 
					
						
							|  |  |  |  |     </select> | 
					
						
							| 
									
										
										
										
											2025-04-28 18:18:42 +08:00
										 |  |  |  | </mapper> |