|
@@ -287,4 +287,93 @@
|
|
|
<include refid="studentPaymentSql"/>
|
|
|
</select>
|
|
|
|
|
|
+ <sql id="queryMusicGroupStudentSql">
|
|
|
+ <where>
|
|
|
+ <if test="search != null and search != ''">
|
|
|
+ AND (su.real_name_ like CONCAT("%",#{search},"%") OR sr.parents_phone_ like CONCAT("%",#{search},"%"))
|
|
|
+ </if>
|
|
|
+ <if test="subjectId != null">
|
|
|
+ AND sr.actual_subject_id_ = #{subjectId}
|
|
|
+ </if>
|
|
|
+ <if test="studentStatus != null and studentStatus != ''">
|
|
|
+ AND sr.music_group_status_ = #{studentStatus}
|
|
|
+ </if>
|
|
|
+ <if test="paymentStatus != null">
|
|
|
+ AND mgsf.payment_status_ = #{paymentStatus}
|
|
|
+ </if>
|
|
|
+ <if test="musicGroupId != null and musicGroupId != ''">
|
|
|
+ AND sr.music_group_id_ = #{musicGroupId}
|
|
|
+ </if>
|
|
|
+ </where>
|
|
|
+ </sql>
|
|
|
+ <resultMap id="MusicGroupStudentsDto" type="com.ym.mec.biz.dal.dto.MusicGroupStudentsDto">
|
|
|
+ <result property="userId" column="user_id_"/>
|
|
|
+ <result property="realName" column="real_name_"/>
|
|
|
+ <result property="phone" column="parents_phone_"/>
|
|
|
+ <result property="currentGrade" column="current_grade_"/>
|
|
|
+ <result property="currentClass" column="current_class_"/>
|
|
|
+ <result property="subjectName" column="subject_name_"/>
|
|
|
+ <result property="studentStatus" column="music_group_status_"/>
|
|
|
+ <result property="paymentStatus" column="payment_status_"/>
|
|
|
+ <result property="musicGroupId" column="music_group_id_"/>
|
|
|
+ <result property="isNewStudent" column="is_new_student_"/>
|
|
|
+ </resultMap>
|
|
|
+ <select id="queryMusicGroupStudent" resultMap="MusicGroupStudentsDto">
|
|
|
+ SELECT sr.user_id_,su.real_name_,su.gender_,sr.parents_phone_,sr.current_grade_,
|
|
|
+ sr.current_class_,sr.music_group_status_,mgsf.payment_status_,s.name_ subject_name_,sr.music_group_id_,
|
|
|
+ IF(sr.create_time_ > mg.payment_expire_date_,1,0) is_new_student_
|
|
|
+ FROM student_registration sr
|
|
|
+ LEFT JOIN sys_user su ON sr.user_id_ = su.id_
|
|
|
+ LEFT JOIN music_group_student_fee_ mgsf ON (mgsf.music_group_id_ = sr.music_group_id_ AND mgsf.user_id_ = sr.user_id_)
|
|
|
+ LEFT JOIN `subject` s ON s.id_ = sr.actual_subject_id_
|
|
|
+ LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
|
|
|
+ <include refid="queryMusicGroupStudentSql"/>
|
|
|
+ <include refid="global.limit"/>
|
|
|
+ </select>
|
|
|
+ <select id="countMusicGroupStudent" resultType="java.lang.Integer">
|
|
|
+ SELECT COUNT(sr.user_id_)
|
|
|
+ FROM student_registration sr
|
|
|
+ LEFT JOIN sys_user su ON sr.user_id_ = su.id_
|
|
|
+ LEFT JOIN music_group_student_fee_ mgsf ON (mgsf.music_group_id_ = sr.music_group_id_ AND mgsf.user_id_ = sr.user_id_)
|
|
|
+ LEFT JOIN `subject` s ON s.id_ = sr.actual_subject_id_
|
|
|
+ <include refid="queryMusicGroupStudentSql"/>
|
|
|
+ </select>
|
|
|
+ <select id="countStudyNum" resultType="java.lang.Integer">
|
|
|
+ SELECT COUNT(sr.user_id_) FROM student_registration sr
|
|
|
+ WHERE sr.music_group_id_ = #{musicGroupId} AND sr.payment_status_ = 1
|
|
|
+ AND sr.music_group_status_ != 'QUIT'
|
|
|
+ </select>
|
|
|
+ <select id="countQuitNum" resultType="java.lang.Integer">
|
|
|
+ SELECT COUNT(sr.user_id_) FROM student_registration sr
|
|
|
+ WHERE sr.music_group_id_ = #{musicGroupId} AND sr.payment_status_ = 1
|
|
|
+ AND sr.music_group_status_ = 'QUIT'
|
|
|
+ </select>
|
|
|
+ <select id="countAddNum" resultType="java.lang.Integer">
|
|
|
+ SELECT COUNT(sr.user_id_) FROM student_registration sr
|
|
|
+ LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_ AND sr.create_time_ > mg.apply_expire_date_
|
|
|
+ WHERE sr.music_group_id_ = #{musicGroupId} and sr.music_group_status_ != 'QUIT'
|
|
|
+ </select>
|
|
|
+
|
|
|
+ <resultMap id="MusicGroupStudentSignDto" type="com.ym.mec.biz.dal.dto.MusicGroupStudentSignDto">
|
|
|
+ <result property="signTime" column="create_time_"/>
|
|
|
+ <result property="name" column="real_name_"/>
|
|
|
+ <result property="signStatus" column="status_"/>
|
|
|
+ <result property="courseScheduleName" column="name_"/>
|
|
|
+ </resultMap>
|
|
|
+ <select id="queryMusicGroupStudentsSign" resultMap="MusicGroupStudentSignDto">
|
|
|
+ SELECT sa.create_time_,su.real_name_,sa.status_,cs.name_
|
|
|
+ FROM student_attendance sa
|
|
|
+ LEFT JOIN sys_user su ON sa.user_id_ = su.id_
|
|
|
+ LEFT JOIN course_schedule cs ON sa.course_schedule_id_ = cs.id_
|
|
|
+ WHERE (cs.type_ = 'NORMAL' OR cs.type_ = 'MIX') AND sa.music_group_id_ = #{search}
|
|
|
+ <include refid="global.limit"/>
|
|
|
+ </select>
|
|
|
+ <select id="countMusicGroupStudentsSign" resultType="java.lang.Integer">
|
|
|
+ SELECT COUNT(sa.id_)
|
|
|
+ FROM student_attendance sa
|
|
|
+ LEFT JOIN sys_user su ON sa.user_id_ = su.id_
|
|
|
+ LEFT JOIN course_schedule cs ON sa.course_schedule_id_ = cs.id_
|
|
|
+ WHERE (cs.type_ = 'NORMAL' OR cs.type_ = 'MIX') AND sa.music_group_id_ = #{search}
|
|
|
+ </select>
|
|
|
+
|
|
|
</mapper>
|