123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119 |
- <?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="com.yonge.cooleshow.biz.dal.dao.CourseGroupDao">
- <resultMap id="BaseResultMap" type="com.yonge.cooleshow.biz.dal.entity.CourseGroup">
- <id column="id_" jdbcType="BIGINT" property="id"/>
- <result column="type_" jdbcType="VARCHAR" property="type"/>
- <result column="teacher_id_" jdbcType="INTEGER" property="teacherId"/>
- <result column="name_" jdbcType="VARCHAR" property="name"/>
- <result column="subject_id_" jdbcType="INTEGER" property="subjectId"/>
- <result column="single_course_minutes_" jdbcType="INTEGER" property="singleCourseMinutes"/>
- <result column="course_num_" jdbcType="INTEGER" property="courseNum"/>
- <result column="complete_course_num_" jdbcType="INTEGER" property="completeCourseNum"/>
- <result column="course_introduce_" jdbcType="VARCHAR" property="courseIntroduce"/>
- <result column="course_price_" jdbcType="VARCHAR" property="coursePrice"/>
- <result column="status_" jdbcType="VARCHAR" property="status"/>
- <result column="sales_start_date_" jdbcType="TIMESTAMP" property="salesStartDate"/>
- <result column="sales_end_date_" jdbcType="TIMESTAMP" property="salesEndDate"/>
- <result column="background_pic_" jdbcType="VARCHAR" property="backgroundPic"/>
- <result column="mix_student_num_" jdbcType="INTEGER" property="mixStudentNum"/>
- <result column="max_student_num_" jdbcType="INTEGER" property="maxStudentNum"/>
- <result column="course_start_time_" jdbcType="TIMESTAMP" property="courseStartTime"/>
- <result column="created_by_" jdbcType="INTEGER" property="createdBy"/>
- <result column="created_time_" jdbcType="TIMESTAMP" property="createdTime"/>
- <result column="updated_by_" jdbcType="INTEGER" property="updatedBy"/>
- <result column="updated_time_" jdbcType="TIMESTAMP" property="updatedTime"/>
- <result column="pre_student_num_" jdbcType="INTEGER" property="preStudentNum"/>
- <result column="im_group_id_" jdbcType="VARCHAR" property="imGroupId"/>
- <result column="reason_" jdbcType="VARCHAR" property="reason"/>
- <result column="course_plan_" jdbcType="VARCHAR" property="coursePlan"/>
- </resultMap>
- <sql id="Base_Column_List">
- id_
- , type_, teacher_id_, name_, subject_id_, single_course_minutes_, course_num_,
- complete_course_num_, course_introduce_, course_price_, status_, sales_start_date_,
- sales_end_date_, background_pic_, mix_student_num_,max_student_num_,pre_student_num_, im_group_id_,
- course_start_time_, created_by_, created_time_, updated_by_, updated_time_,reason_,course_plan_
- </sql>
- <insert id="insertBatch" keyColumn="id_" keyProperty="id" useGeneratedKeys="true"
- parameterType="com.yonge.cooleshow.biz.dal.entity.CourseGroup">
- insert into course_group(type_, teacher_id_, name_, subject_id_, single_course_minutes_, course_num_,
- complete_course_num_, course_introduce_, course_price_, status_, sales_start_date_, sales_end_date_, background_pic_,
- mix_student_num_,max_student_num_,pre_student_num_,im_group_id_, course_start_time_, created_by_, created_time_, updated_by_, updated_time_,reason_,course_plan_)
- values
- <foreach collection="entities" item="entity" separator=",">
- (#{entity.type}, #{entity.teacherId}, #{entity.name}, #{entity.subjectId}, #{entity.singleCourseMinutes},
- #{entity.courseNum}, #{entity.completeCourseNum}, #{entity.courseIntroduce}, #{entity.coursePrice}, #{entity.status},
- #{entity.salesStartDate}, #{entity.salesEndDate}, #{entity.backgroundPic}, #{entity.mixStudentNum},#{entity.maxStudentNum},
- #{entity.preStudentNum},#{entity.imGroupId},#{entity.courseStartTime}, #{entity.createdBy}, #{entity.createdTime}, #{entity.updatedBy},
- #{entity.updatedTime},#{entity.reason},#{entity.coursePlan})
- </foreach>
- </insert>
- <select id="queryTeacherCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVo">
- select distinct
- b.id_ as courseGroupId,
- b.name_ as courseGroupName,
- s.name_ as subjectName,
- b.teacher_id_ as teacherId,
- u.username_ as teacherName,
- b.course_start_time_ as courseStartTime,
- b.single_course_minutes_ as singleCourseMinutes,
- b.status_ as `status`,
- ifnull(b.pre_student_num_, 0) as studentCount,
- b.background_pic_ as backgroundPic,
- b.course_price_ as coursePrice,
- b.course_num_ as courseNum,
- u.avatar_ as avatar,
- b.sales_start_date_ as salesStartDate,
- b.sales_end_date_ as salesEndDate,
- b.mix_student_num_ as mixStudentNum,
- b.max_student_num_ as maxStudentNum,
- b.im_group_id_ as imGroupId,
- b.reason_ as reason,
- b.course_plan_ as coursePlan,
- b.course_introduce_ as courseIntroduce,
- 0 as existBuy
- from course_group as b
- left join subject as s on b.subject_id_ = s.id_
- left join sys_user as u on b.teacher_id_ = u.id_
- <where>
- u.del_flag_ = 0
- <if test="param.teacherId != null">
- and b.teacher_id_ = #{param.teacherId}
- </if>
- <if test="param.groupStatus != null">
- and b.status_ = #{param.groupStatus}
- </if>
- <if test="param.subjectId != null">
- AND b.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.search != null and param.search !=''">
- and (
- u.username_ like concat('%',#{param.search},'%')
- or b.name_ like concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.type != null and param.type != ''">
- and b.type_ = #{param.type}
- </if>
- </where>
- order by b.created_time_
- </select>
- <select id="queryStudentCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVo">
- select distinct b.id_ as courseGroupId,
- b.name_ as courseGroupName,
- s.name_ as subjectName,
- b.teacher_id_ as teacherId,
- u.username_ as teacherName,
- b.course_start_time_ as courseStartTime,
- b.single_course_minutes_ as singleCourseMinutes,
- b.status_ as `status`,
- ifnull(b.pre_student_num_, 0) as studentCount,
- b.background_pic_ as backgroundPic,
- b.course_price_ as coursePrice,
- b.course_num_ as courseNum,
- u.avatar_ as avatar,
- b.sales_start_date_ as salesStartDate,
- b.sales_end_date_ as salesEndDate,
- b.mix_student_num_ as mixStudentNum,
- b.max_student_num_ as maxStudentNum,
- b.im_group_id_ as imGroupId,
- b.reason_ as reason,
- b.course_plan_ as coursePlan,
- b.course_introduce_ as courseIntroduce,
- if(y.status_ = 'PAID', 1, 0) as existBuy
- from course_group as b
- left join subject as s on b.subject_id_ = s.id_
- left join sys_user as u on b.teacher_id_ = u.id_
- left join
- (select x.user_id_, x.course_group_id_, o.status_
- from course_schedule_student_payment as x
- left join user_order as o on x.order_no_ = o.order_no_ and x.user_id_ = o.user_id_
- left join user_order_detail as d on d.order_no_ = x.order_no_
- where x.user_id_ = #{param.studentId}) as y on b.id_ = y.course_group_id_
- <where>
- u.del_flag_ = 0
- <if test="param.teacherId != null">
- and b.teacher_id_ = #{param.teacherId}
- </if>
- <if test="param.groupStatus != null">
- and b.status_ = #{param.groupStatus}
- </if>
- <if test="param.subjectId != null">
- AND b.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.search != null and param.search !=''">
- and (
- u.real_name_ like concat('%',#{param.search},'%')
- or b.name_ like concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.auditVersion != null ">
- and #{param.auditVersion} = b.audit_version_
- </if>
- <if test="param.subjectId != null ">
- and #{param.subjectId} = b.subject_id_
- </if>
- <if test="param.type != null and param.type != ''">
- and b.type_ = #{param.type}
- </if>
- </where>
- </select>
- <select id="selectAdminLivePage" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
- select distinct
- cg.id_ as courseGroupId,
- cg.reason_ as reason,
- cg.name_ as name,
- cg.complete_course_num_ as endCourseNum,
- if(cg.complete_course_num_ = 0 ,cg.course_num_,cg.course_num_ - cg.complete_course_num_) as noStartCourseNum,
- cg.course_price_ as coursePrice,
- cg.pre_student_num_ as preStudentNum,
- cg.status_ as status,
- cg.course_num_ as courseNum,
- cg.created_time_ as createTime,
- cg.course_introduce_ as courseIntroduce,
- <if test="param.studentId != null">
- cssp.order_no_ as orderNo,
- </if>
- cg.im_group_id_ as imGroupId,
- cg.course_plan_ as coursePlan
- from course_group cg
- left join course_schedule_student_payment cssp on cg.id_ = cssp.course_group_id_
- left join sys_user su on su.id_ = cssp.user_id_
- <where>
- <if test="param.teacherId != null">
- and #{param.teacherId} = cg.teacher_id_
- </if>
- <if test="param.studentId != null">
- and #{param.studentId} = cssp.user_id_
- </if>
- <if test="param.search != null and param.search !=''">
- and (
- cg.id_ like concat('%',#{param.search},'%')
- or cg.name_ like concat('%',#{param.search},'%')
- or su.id_ like concat('%',#{param.search},'%')
- or su.username_ like concat('%',#{param.search},'%')
- or su.phone_ like concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.orderNo != null and param.orderNo != ''">
- and cssp.order_no_ like concat('%',#{param.orderNo},'%')
- </if>
- <if test="param.subjectId != null">
- and #{param.subjectId} = cg.subject_id_
- </if>
- <if test="param.status != null">
- and #{param.status} = cg.status_
- </if>
- <if test="param.startTime != null">
- and #{param.startTime} <= cg.created_time_
- </if>
- <if test="param.endTime != null">
- and #{param.endTime} >= cg.created_time_
- </if>
- <if test="param.courseType != null">
- and #{param.courseType} = cg.type_
- </if>
- </where>
- order by cg.id_ desc
- </select>
- <select id="selectCourseGroupSubject" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
- select
- cg.id_ as courseGroupId,
- s.name_ as subjectName
- from course_group cg
- left join subject s on cg.subject_id_ = s.id_
- <where>
- <if test="courseGroupIdList != null and courseGroupIdList.size() != 0">
- and cg.id_ in
- <foreach collection="courseGroupIdList" item="item" open="(" close=")" separator=",">
- #{item}
- </foreach>
- </if>
- </where>
- </select>
- <select id="selectAdminLiveStudentPage" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupStudentVo">
- select
- a.id_ as paymentId,
- su.id_ as studentId,
- su.username_ as studentName,
- a.actual_price_ as price,
- a.order_no_ as orderNo,
- su.phone_ as phone,
- a.create_time_ as payTime
- from user_order_detail as a
- left join user_order as o on a.order_no_ = o.order_no_
- left join sys_user as su on o.user_id_ = su.id_
- <where>
- a.good_type_ = 'LIVE' and o.status_ = 'PAID'
- <if test="param.courseGroupId != null">
- and #{param.courseGroupId} = a.biz_id_
- </if>
- <if test="param.search != null and param.search != ''">
- and (
- a.biz_id_ like concat('%',#{param.search},'%')
- or su.id_ like concat('%',#{param.search},'%')
- or su.username_ like concat('%',#{param.search},'%')
- or su.phone_ like concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.orderNo != null and param.orderNo != ''">
- and a.order_no_ like concat('%',#{param.orderNo},'%')
- </if>
- <if test="param.startTime != null">
- and #{param.startTime} <= a.create_time_
- </if>
- <if test="param.endTime != null">
- and #{param.endTime} >= a.create_time_
- </if>
- </where>
- group by o.user_id_
- order by a.id_ desc
- </select>
- <select id="selectAdminLivePlan" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupPlanVo">
- select
- cs.id_ as courseId,
- cs.class_num_ as classNum,
- cs.class_date_ as classDate,
- cs.start_time_ as startTime,
- cs.end_time_ as endTime,
- cs.status_ as courseStatus,
- cp.plan_ as planInfo,
- lrv.url_ as videoUrl
- from course_schedule cs
- left join live_room_video lrv on cs.id_ = lrv.course_id_
- left join course_plan cp on cp.course_group_id_ = cs.course_group_id_ and cp.class_num_ = cs.class_num_
- <where>
- <if test="courseGroupId != null">
- and #{courseGroupId} = cs.course_group_id_
- </if>
- </where>
- order by cs.class_num_
- </select>
- <select id="selectAdminLiveCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
- select distinct
- cg.id_ as courseGroupId,
- cg.name_ as name,
- cg.complete_course_num_ as endCourseNum,
- if(cg.complete_course_num_ = 0 ,cg.course_num_,cg.course_num_ - cg.complete_course_num_) as noStartCourseNum,
- cg.course_price_ as coursePrice,
- cg.pre_student_num_ as preStudentNum,
- cg.status_ as status,
- cg.course_num_ as courseNum,
- cg.created_time_ as createTime,
- cg.course_introduce_ as courseIntroduce,
- cg.type_ as type,
- s.name_ as subjectName,
- cg.course_plan_ as coursePlan
- from course_group cg
- left join course_schedule_student_payment cssp on cg.id_ = cssp.course_group_id_
- left join subject s on cg.subject_id_ = s.id_
- <where>
- <if test="courseGroupId != null">
- and #{courseGroupId} = cg.id_
- </if>
- </where>
- </select>
- <select id="selectAdminLiveStudentCoursePage"
- resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupStudentCourseVo">
- select distinct
- cs.id_ as courseId,
- cs.class_date_ as classDate,
- cs.start_time_ as startTime,
- cs.end_time_ as endTime,
- cs.status_ as courseStatue,
- cssp.order_no_ as orderNo,
- sa.id_ as studentAttendanceId
- from course_schedule cs
- left join course_schedule_student_payment cssp on cs.id_ = cssp.course_id_
- left join student_attendance sa on cssp.course_id_ = sa.course_schedule_id_
- <where>
- cs.status_ != '${@ com.yonge.cooleshow.biz.dal.enums.CourseScheduleEnum@CANCEL}'
- <if test="param.studentId != null">
- and cssp.user_id_ = #{param.studentId}
- </if>
- <if test="param.status != null">
- <choose>
- <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@TRUANT">
- and sa.id_ is null
- </when>
- <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@ATTENDCLASS">
- and sa.id_ is not null
- and #{param.studentId} = sa.student_id_
- </when>
- <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@NOTSTART">
- and cs.status_ = '${@ com.yonge.cooleshow.biz.dal.enums.CourseScheduleEnum@NOT_START}'
- </when>
- </choose>
- </if>
- <if test="param.courseGroupId != null">
- and #{param.courseGroupId} = cs.course_group_id_
- </if>
- <if test="param.courseId != null">
- and cs.id_ like concat('%',#{param.courseId},'%')
- </if>
- </where>
- order by cs.id_ desc
- </select>
- <select id="selectPracticeGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPracticeVo">
- SELECT
- cg.id_ AS groupId,
- cg.name_ AS groupName,
- cg.subject_id_ AS subjectId,
- sub.name_ AS subjectName,
- cg.course_num_ AS courseNum,
- IFNULL(cs.count_ ,0)AS completeCount,
- cg.teacher_id_ AS teacherId,
- tu.username_ AS teacherName,
- tu.real_name_ AS teacherRealName,
- sp.user_id_ AS studentId,
- su.username_ AS studentName,
- su.real_name_ AS studentRealName,
- cg.status_ AS `status`,
- cst.start_time_ AS startTime,
- cg.course_plan_ AS coursePlan
- FROM course_group cg
- LEFT JOIN `subject` sub ON cg.subject_id_=sub.id_
- LEFT JOIN sys_user tu ON cg.teacher_id_=tu.id_
- LEFT JOIN (SELECT user_id_,course_group_id_ FROM course_schedule_student_payment WHERE course_type_=#{param.groupType} GROUP BY course_group_id_) sp ON cg.id_=sp.course_group_id_
- LEFT JOIN sys_user su ON sp.user_id_=su.id_
- LEFT JOIN (SELECT course_group_id_,COUNT(1) AS count_ FROM course_schedule WHERE type_= #{param.groupType} AND status_='COMPLETE' GROUP BY course_group_id_) cs ON cg.id_=cs.course_group_id_
- LEFT JOIN (SELECT course_group_id_,start_time_ FROM course_schedule WHERE type_=#{param.groupType} GROUP BY course_group_id_) cst ON cg.id_=cst.course_group_id_
- WHERE cg.type_=#{param.groupType} AND cg.status_ IN('ING','COMPLETE')
- <if test="param.search != null and param.search != ''">
- AND (
- cg.id_ LIKE concat('%',#{param.search},'%') OR
- cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
- sp.user_id_ LIKE concat('%',#{param.search},'%') OR
- cg.name_ LIKE concat('%',#{param.search},'%') OR
- tu.username_ LIKE concat('%',#{param.search},'%') OR
- su.username_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.subjectId != null">
- AND cg.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.status != null and param.status != ''">
- AND cg.status_ = #{param.status}
- </if>
- <if test="param.studentId != null">
- AND sp.user_id_ = #{param.studentId}
- </if>
- <if test="param.teacherId != null">
- AND cg.teacher_id_ = #{param.teacherId}
- </if>
- </select>
- <select id="selectPracticeGroupDetail"
- resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPracticeDetailVo">
- SELECT * FROM
- (SELECT
- cs.id_ AS courseId,
- sb.name_ AS subjectName,
- cs.teacher_id_ AS teacherId,
- tu.username_ AS teacherName,
- tu.real_name_ AS teacherRealName,
- sp.user_id_ AS studentId,
- su.username_ AS studentName,
- su.real_name_ AS studentRealName,
- cs.status_ AS `status`,
- cs.start_time_ AS startTime,
- cs.end_time_ AS endTime,
- cs.class_date_ AS classDate,
- (CASE WHEN cs.start_time_ >= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
- (CASE WHEN cs.end_time_ <= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign,
- (CASE WHEN cs.start_time_ >= sa.sign_in_time_ THEN 1 ELSE 0 END) AS studentInSign,
- (CASE WHEN cs.end_time_ <= sa.sign_out_time_ THEN 1 ELSE 0 END) AS studentOutSign,
- ts.status_ AS salaryStatus
- FROM course_schedule cs
- LEFT JOIN course_group cg ON cs.course_group_id_=cg.id_
- LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
- LEFT JOIN sys_user tu ON cs.teacher_id_=tu.id_
- LEFT JOIN course_schedule_student_payment sp ON cs.id_=sp.course_id_
- LEFT JOIN sys_user su ON sp.user_id_=su.id_
- LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
- LEFT JOIN student_attendance sa ON cs.id_=sa.course_schedule_id_
- LEFT JOIN course_schedule_teacher_salary ts ON cs.id_=ts.course_schedule_id_
- WHERE cs.lock_=0 AND cs.course_group_id_ = #{param.courseGroupId}) a
- <where>
- <if test="param.search != null and param.search != ''">
- AND (
- courseId LIKE concat('%',#{param.search},'%') OR
- teacherName LIKE concat('%',#{param.search},'%') OR
- teacherId LIKE concat('%',#{param.search},'%') OR
- studentName LIKE concat('%',#{param.search},'%') OR
- studentId LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.teacherSign == 1">
- AND teacherInSign = #{param.teacherSign}
- </if>
- <if test="param.teacherSign == 0">
- AND teacherOutSign = #{param.teacherSign}
- </if>
- <if test="param.studentSign == 1">
- AND studentInSign = #{param.studentSign}
- </if>
- <if test="param.studentSign == 0">
- AND studentOutSign = #{param.studentSign}
- </if>
- <if test="param.status != null and param.status != ''">
- AND `status` = #{param.status}
- </if>
- <if test="param.salaryStatus != null and param.salaryStatus != ''">
- AND salaryStatus = #{param.salaryStatus}
- </if>
- <if test="param.startTime != null">
- AND classDate BETWEEN #{param.startTime} AND #{param.endTime}
- </if>
- <if test="param.studentId != null">
- AND studentId = #{param.studentId}
- </if>
- <if test="param.teacherId != null">
- AND teacherId = #{param.teacherId}
- </if>
- </where>
- </select>
- <select id="selectLiveGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupLiveVo">
- SELECT
- cg.id_ AS courseGroupId,
- cg.name_ AS courseGroupName,
- cg.subject_id_ AS subjectId,
- sb.name_ AS subjectName,
- cg.teacher_id_ AS teacherId,
- su.username_ AS teacherName,
- su.real_name_ AS teacherRealName,
- cg.course_num_ AS courseNum,
- cg.pre_student_num_ AS studentNum,
- cg.status_ AS `status`,
- IFNULL(cm.count_,0) AS completeCount,
- st.start_time_ AS startTime,
- cg.course_plan_ AS coursePlan
- FROM course_group cg
- LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
- LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
- LEFT JOIN (SELECT course_group_id_,COUNT(1) AS count_ FROM course_schedule WHERE type_ = #{param.groupType} AND status_='COMPLETE' GROUP BY course_group_id_) cm ON cg.id_=cm.course_group_id_
- LEFT JOIN (SELECT course_group_id_,start_time_ FROM course_schedule WHERE type_ = #{param.groupType} GROUP BY course_group_id_) st ON cg.id_=st.course_group_id_
- <where>
- <if test="param.search != null and param.search != ''">
- AND (
- cg.id_ LIKE concat('%',#{param.search},'%') OR
- cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
- cg.name_ LIKE concat('%',#{param.search},'%') OR
- su.username_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.subjectId != null">
- AND cg.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.groupType != null and param.groupType != ''">
- AND cg.type_ = #{param.groupType}
- </if>
- <if test="param.status != null and param.status != ''">
- AND cg.status_ = #{param.status}
- </if>
- </where>
- </select>
- <select id="selectLiveGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseSchedulePaymentVo">
- SELECT
- p.user_id_ AS studentId,
- u.username_ AS studentName,
- u.real_name_ AS studentRealName,
- u.phone_ AS studentPhone,
- p.actual_price_ AS actualPrice,
- p.order_no_ AS orderNo,
- o.create_time_ AS createdOrderTime
- FROM course_schedule_student_payment p
- LEFT JOIN sys_user u ON p.user_id_=u.id_
- LEFT JOIN user_order o ON p.order_no_ = o.order_no_
- WHERE p.course_group_id_=#{param.groupId}
- <if test="param.search != null and param.search != ''">
- AND (
- p.course_id_ LIKE concat('%',#{param.search},'%') OR
- p.user_id_ LIKE concat('%',#{param.search},'%') OR
- u.username_ LIKE concat('%',#{param.search},'%') OR
- u.phone_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.orderNo != null and param.orderNo != ''">
- AND p.order_no_ = #{param.orderNo}
- </if>
- <if test="param.startTime != null">
- AND o.create_time_ <= #{param.startTime}
- </if>
- <if test="param.endTime != null">
- AND o.create_time_ >= #{param.endTime}
- </if>
- </select>
- <select id="selectLiveGroupPlan" resultType="com.yonge.cooleshow.biz.dal.vo.CourseSchedulePlanVo">
- SELECT
- distinct
- cs.id_ AS courseId,
- cp.plan_ AS courseIntroduce,
- cs.class_num_ AS classNum,
- cs.class_date_ AS classDate,
- cs.start_time_ AS startTime,
- cs.end_time_ AS endTime,
- ts.status_ AS salaryStatus,
- (select group_concat(lrv.url_) from live_room_video lrv where lrv.course_id_ = cs.id_)AS url,
- cs.status_ AS courseStatus,
- (CASE WHEN cs.start_time_ >= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
- (CASE WHEN cs.end_time_ <= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign
- FROM course_schedule cs
- LEFT JOIN course_group g ON cs.course_group_id_=g.id_
- LEFT JOIN course_schedule_teacher_salary ts ON cs.id_=ts.course_schedule_id_
- LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
- left join course_plan cp on cp.course_group_id_ = cs.course_group_id_ and cp.class_num_ = cs.class_num_
- WHERE cs.course_group_id_= #{param.groupId}
- <if test="param.salaryStatus != null and param.salaryStatus != ''">
- AND ts.status_ = #{param.salaryStatus}
- </if>
- <if test="param.startTime != null">
- AND cs.start_time_ <= #{param.startTime}
- </if>
- <if test="param.endTime != null">
- AND cs.end_time_ >= #{param.endTime}
- </if>
- <if test="param.endTime != null">
- AND cs.id_ LIKE concat('%',#{param.courseId},'%')
- </if>
- </select>
- <select id="selectVideoGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVideoVo">
- SELECT
- g.id_ AS groupId,
- g.lesson_name_ AS lessonName,
- g.lesson_subject_ AS subjectId,
- s.name_ AS subjectName,
- g.lesson_count_ AS lessonCount,
- IFNULL(p.count_,0) AS buyCount,
- g.teacher_id_ AS teacherId,
- u.username_ AS teacherName,
- g.pay_type_ AS payType,
- u.real_name_ AS teacherRealName,
- g.create_time_ AS createTime,
- g.shelves_time_ AS recordTime,
- g.shelves_flag_ as shelvesFlag,
- g.sort_number_ as sortNumber,
- g.top_flag_ as topFlag,
- g.audit_status_ as status,
- g.relation_type_ as relationType,
- g.draft_flag_ as draftFlag
- FROM video_lesson_group g
- LEFT JOIN `subject` s ON g.lesson_subject_=s.id_
- LEFT JOIN sys_user u ON g.teacher_id_=u.id_
- LEFT JOIN (
- SELECT video_lesson_group_id_,COUNT(1) AS count_ FROM video_lesson_purchase_record
- WHERE order_status_='PAID' GROUP BY video_lesson_group_id_) p ON g.id_=p.video_lesson_group_id_
- <where>
- <if test="param.search != null and param.search != ''">
- AND (
- g.id_ LIKE concat('%',#{param.search},'%') OR
- g.lesson_name_ LIKE concat('%',#{param.search},'%') OR
- g.teacher_id_ LIKE concat('%',#{param.search},'%') OR
- u.username_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.subjectId != null and param.subjectId != ''">
- AND g.lesson_subject_ = #{param.subjectId}
- </if>
- <if test="param.status != null and param.status != ''">
- AND g.audit_status_ = #{param.status}
- </if>
- <if test="param.shelvesFlag != null">
- AND g.shelves_flag_ = #{param.shelvesFlag}
- </if>
- <if test="param.draftFlag != null">
- AND g.draft_flag_ = #{param.draftFlag}
- </if>
- <if test="param.topFlag != null">
- AND g.top_flag_ = #{param.topFlag}
- </if>
- <if test="param.relationType != null">
- AND g.relation_type_ = #{param.relationType}
- </if>
- <if test="param.payType != null">
- AND g.pay_type_ = #{param.payType}
- </if>
- </where>
- order by g.top_flag_ desc ,g.sort_number_ desc,g.id_ desc
- </select>
- <select id="selectVideoGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupStudentVo">
- SELECT
- r.student_id_ AS studentId,
- u.username_ AS studentName,
- u.real_name_ AS studentRealName,
- u.phone_ AS studentPhone,
- r.order_no_ AS orderNo,
- r.pay_money_ AS payMoney,
- o.create_time_ AS createTime
- FROM video_lesson_purchase_record r
- LEFT JOIN sys_user u ON r.student_id_=u.id_
- LEFT JOIN user_order o ON r.order_no_=o.order_no_
- WHERE r.order_status_='PAID'
- AND video_lesson_group_id_ = #{param.groupId}
- <if test="param.search != null and param.search != ''">
- AND (
- r.student_id_ LIKE concat('%',#{param.search},'%') OR
- u.username_ LIKE concat('%',#{param.search},'%') OR
- u.phone_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.orderNo != null and param.orderNo != ''">
- AND r.order_no_ = #{param.orderNo}
- </if>
- <if test="param.startTime != null">
- AND o.create_time_ <= #{param.startTime}
- </if>
- <if test="param.endTime != null">
- AND o.create_time_ >= #{param.endTime}
- </if>
- </select>
- <select id="selectVideoGroupPlan" resultType="com.yonge.cooleshow.biz.dal.entity.VideoLessonGroupDetail">
- SELECT
- id_ AS id,
- video_title_ AS videoTitle,
- video_content_ AS videoContent,
- video_url_ AS videoUrl,
- cover_url_ AS coverUrl
- FROM video_lesson_group_detail
- WHERE video_lesson_group_id_=#{param.groupId}
- </select>
- <select id="selectGroupInfoVo" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupInfoVo"
- parameterType="java.lang.Long">
- SELECT
- g.id_ AS id,
- g.name_ AS name,
- g.subject_id_ AS subjectId,
- s.name_ AS subjectName,
- g.course_num_ AS courseNum,
- g.course_price_ AS coursePrice,
- g.status_ AS `status`,
- g.course_introduce_ AS courseIntroduce,
- g.created_time_ AS createdTime,
- g.course_plan_ AS coursePlan
- FROM course_group g
- LEFT JOIN `subject` s ON g.subject_id_=s.id_
- WHERE g.id_ =#{groupId}
- </select>
- <update id="opsPreStudentNum">
- update course_group
- set
- pre_student_num_ = pre_student_num_ + #{num}
- where id_ = #{id}
- </update>
- <update id="updateBatch">
- UPDATE course_group
- SET status_='COMPLETE'
- WHERE id_ IN
- <foreach collection="list" item="item" open="(" separator="," close=")">
- #{item}
- </foreach>
- </update>
- <update id="updateCompleteCourseNum">
- update course_group cg
- left join (
- select cs.course_group_id_,COUNT(cs.id_) num_ from course_schedule cs
- where cs.course_group_id_ IN
- <foreach collection="groupIds" item="item" open="(" separator="," close=")">
- #{item}
- </foreach>
- AND cs.status_ = 'COMPLETE'
- group by cs.course_group_id_) cs ON cs.course_group_id_ = cg.id_
- set cg.complete_course_num_ = cs.num_
- where cs.course_group_id_ = cg.id_
- </update>
- <update id="updateExposureNum">
- update course_group
- set exposure_num_ = exposure_num_ + #{exposureNum}
- where id_ = #{groupId}
- </update>
- <select id="selectPianoGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
- SELECT
- cg.id_ AS courseGroupId,
- cg.name_ AS courseGroupName,
- cg.subject_id_ AS subjectId,
- sb.name_ AS subjectName,
- cg.teacher_id_ AS teacherId,
- su.username_ AS teacherName,
- su.real_name_ AS teacherRealName,
- cg.course_num_ AS courseNum,
- cg.status_ AS `status`,
- cg.course_plan_ AS coursePlan,
- IFNULL(cm.count_,0) AS completeCount,
- st.start_time_ AS startTime
- FROM course_group cg
- LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
- LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
- LEFT JOIN (SELECT course_group_id_,COUNT(1) AS count_ FROM course_schedule WHERE type_='PIANO_ROOM_CLASS' AND status_='COMPLETE' GROUP BY course_group_id_) cm ON cg.id_=cm.course_group_id_
- LEFT JOIN (SELECT course_group_id_,start_time_ FROM course_schedule WHERE type_='PIANO_ROOM_CLASS' GROUP BY course_group_id_) st ON cg.id_=st.course_group_id_
- WHERE cg.type_='PIANO_ROOM_CLASS'
- <if test="param.search != null and param.search != ''">
- AND (
- cg.id_ LIKE concat('%',#{param.search},'%') OR
- cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
- cg.name_ LIKE concat('%',#{param.search},'%') OR
- su.username_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.subjectId != null">
- AND cg.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.status != null and param.status != ''">
- AND cg.status_ = #{param.status}
- </if>
- order by st.start_time_ desc,cg.id_ desc
- </select>
- <select id="selectPianoGroupDetail"
- resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoDetailVo">
- SELECT
- cs.id_ AS courseId,
- sb.id_ AS subjectId,
- sb.name_ AS subjectName,
- cs.teacher_id_ AS teacherId,
- tu.username_ AS teacherName,
- tu.real_name_ AS teacherRealName,
- cs.status_ AS `status`,
- a.studentCount AS studentCount,
- (cs.single_course_time_ * (a.studentCount+1)*(a.studentCount+1-1)) AS courseTime,
- cs.start_time_ AS startTime,
- cs.end_time_ AS endTime,
- b.teacherInSign AS teacherInSign,
- b.teacherOutSign AS teacherOutSign
- FROM course_schedule cs
- LEFT JOIN course_group cg ON cs.course_group_id_ = cg.id_
- LEFT JOIN `subject` sb ON cg.subject_id_ = sb.id_
- LEFT JOIN sys_user tu ON cs.teacher_id_ = tu.id_
- LEFT JOIN (SELECT course_id_,COUNT(1) AS studentCount FROM course_schedule_student_payment WHERE course_type_='PIANO_ROOM_CLASS' GROUP BY course_id_) a ON cs.id_=a.course_id_
- LEFT JOIN (SELECT cs.id_ AS cid,( CASE WHEN cs.start_time_ >= ta.sign_in_time_ THEN 1 ELSE 0 END ) AS teacherInSign,( CASE WHEN cs.end_time_ <= ta.sign_out_time_ THEN 1 ELSE 0 END ) AS teacherOutSign
- FROM course_schedule cs LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_ WHERE cs.type_='PIANO_ROOM_CLASS') b ON cs.id_=b.cid
- WHERE cs.type_='PIANO_ROOM_CLASS'
- AND cs.course_group_id_=#{param.courseGroupId}
- <if test="param.search != null and param.search != ''">
- AND cs.id_ LIKE concat('%',#{param.search},'%')
- </if>
- <if test="param.status != null and param.status != ''">
- AND cs.status_ = #{param.status}
- </if>
- <if test="param.startTime != null">
- AND cs.start_time_ >= #{param.startTime}
- </if>
- <if test="param.endTime != null">
- AND cs.start_time_ <= #{param.endTime}
- </if>
- <if test="param.teacherSign == 1">
- AND b.teacherInSign = #{param.teacherSign}
- </if>
- <if test="param.teacherSign == 0">
- AND b.teacherOutSign = #{param.teacherSign}
- </if>
- <if test="param.studentSign != null">
- AND cs.id_ IN
- <foreach collection="param.courseIds" item="item" open="(" close=")" separator=",">
- #{item}
- </foreach>
- </if>
- </select>
- <select id="studentSign" resultType="com.yonge.cooleshow.biz.dal.vo.StudentSignVo">
- SELECT DISTINCT
- p.course_id_ AS courseId,
- p.user_id_ AS userId,
- u.username_ AS userName,
- u.real_name_ AS realName,
- ( CASE WHEN c.start_time_ >= a.sign_in_time_ THEN 1 ELSE 0 END ) AS studentInSign,
- ( CASE WHEN c.end_time_ <= a.sign_out_time_ THEN 1 ELSE 0 END ) AS studentOutSign
- FROM course_schedule_student_payment p
- LEFT JOIN sys_user u ON p.user_id_=u.id_
- LEFT JOIN course_schedule c ON p.course_id_=c.id_
- LEFT JOIN student_attendance a ON p.user_id_=a.student_id_ and a.course_schedule_id_ = c.id_
- <where>
- <if test="courseId !=null">
- AND p.course_id_=#{courseId}
- </if>
- <if test="type !=null and type!=''">
- AND p.course_type_=#{type}
- </if>
- </where>
- </select>
- <select id="selectPianoGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
- SELECT DISTINCT
- g.id_ AS courseGroupId,
- g.name_ AS courseGroupName,
- s.id_ AS subjectId,
- s.name_ AS subjectName,
- g.teacher_id_ AS teacherId,
- u.username_ AS teacherName,
- u.real_name_ AS teacherRealName,
- g.course_num_ AS courseNum,
- IFNULL(cm.count_,0) AS completeCount,
- g.status_ AS `status`,
- st.start_time_ AS startTime
- FROM course_schedule_student_payment p
- LEFT JOIN course_group g ON p.course_group_id_=g.id_
- LEFT JOIN `subject` s ON g.subject_id_=s.id_
- LEFT JOIN sys_user u ON g.teacher_id_=u.id_
- LEFT JOIN (SELECT course_group_id_,COUNT(1) AS count_ FROM course_schedule WHERE type_='PIANO_ROOM_CLASS' AND status_='COMPLETE' GROUP BY course_group_id_) cm ON p.course_group_id_=cm.course_group_id_
- LEFT JOIN (SELECT course_group_id_,start_time_ FROM course_schedule WHERE type_='PIANO_ROOM_CLASS' GROUP BY course_group_id_) st ON p.course_group_id_=st.course_group_id_
- WHERE p.course_type_='PIANO_ROOM_CLASS'
- AND p.user_id_=#{param.studentId}
- <if test="param.search != null and param.search != ''">
- AND (
- g.id_ LIKE concat('%',#{param.search},'%') OR
- g.teacher_id_ LIKE concat('%',#{param.search},'%') OR
- u.username_ LIKE concat('%',#{param.search},'%') OR
- g.name_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.subjectId != null">
- AND s.id_ = #{param.subjectId}
- </if>
- <if test="param.status != null and param.status != ''">
- AND g.status_ = #{param.status}
- </if>
- </select>
- <select id="selectPianoGroupStudentDetail"
- resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoDetailVo">
- SELECT * FROM (
- SELECT
- cs.id_ AS courseId,
- sb.id_ AS subjectId,
- sb.name_ AS subjectName,
- cs.teacher_id_ AS teacherId,
- tu.username_ AS teacherName,
- tu.real_name_ AS teacherRealName,
- cs.status_ AS `status`,
- a.studentCount AS studentCount,
- (cs.single_course_time_ * (a.studentCount+1)*(a.studentCount+1-1)) AS courseTime,
- cs.start_time_ AS startTime,
- cs.end_time_ AS endTime,
- p.user_id_ AS studentId,
- su.username_ AS studentName,
- su.real_name_ AS studentRealName,
- (CASE WHEN cs.start_time_ >= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
- (CASE WHEN cs.end_time_ <= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign,
- (CASE WHEN cs.start_time_ >= sa.sign_in_time_ THEN 1 ELSE 0 END) AS studentInSign,
- (CASE WHEN cs.end_time_ <= sa.sign_out_time_ THEN 1 ELSE 0 END) AS studentOutSign,
- (CASE WHEN cs.start_time_ >= sa.sign_in_time_ AND cs.end_time_ <= sa.sign_out_time_ THEN 1 ELSE 0 END) AS studentSign,
- (CASE WHEN cs.start_time_ >= ta.sign_in_time_ AND cs.end_time_ <= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherSign
- FROM course_schedule cs
- LEFT JOIN course_group cg ON cs.course_group_id_ = cg.id_
- LEFT JOIN `subject` sb ON cg.subject_id_ = sb.id_
- LEFT JOIN sys_user tu ON cs.teacher_id_ = tu.id_
- LEFT JOIN (SELECT course_id_,COUNT(1) AS studentCount FROM course_schedule_student_payment WHERE course_type_='PIANO_ROOM_CLASS' GROUP BY course_id_) a ON cs.id_=a.course_id_
- LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
- LEFT JOIN student_attendance sa ON cs.id_=sa.course_schedule_id_
- LEFT JOIN course_schedule_student_payment p ON cs.id_=p.course_id_
- LEFT JOIN sys_user su ON p.user_id_ = su.id_
- WHERE cs.type_='PIANO_ROOM_CLASS'
- AND p.user_id_=#{param.studentId}
- AND p.course_group_id_=#{param.courseGroupId}) m
- <where>
- <if test="param.search != null and param.search != ''">
- AND courseId LIKE concat('%',#{param.search},'%')
- </if>
- <if test="param.studentSign != null">
- AND studentSign = #{param.studentSign}
- </if>
- <if test="param.teacherSign != null">
- AND teacherSign = #{param.teacherSign}
- </if>
- <if test="param.status != null and param.status != ''">
- AND `status` = #{param.status}
- </if>
- <if test="param.startTime != null">
- AND startTime >= #{param.startTime}
- </if>
- <if test="param.endTime != null">
- AND startTime <= #{param.endTime}
- </if>
- </where>
- </select>
- <select id="selectPianoGroupTeacher" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
- SELECT
- cg.id_ AS courseGroupId,
- cg.name_ AS courseGroupName,
- cg.subject_id_ AS subjectId,
- sb.name_ AS subjectName,
- cg.teacher_id_ AS teacherId,
- su.username_ AS teacherName,
- su.real_name_ AS teacherRealName,
- cg.course_num_ AS courseNum,
- cg.status_ AS `status`,
- IFNULL(cm.count_,0) AS completeCount,
- cg.course_plan_ AS coursePlan,
- st.start_time_ AS startTime
- FROM course_group cg
- LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
- LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
- LEFT JOIN (SELECT course_group_id_,COUNT(1) AS count_ FROM course_schedule WHERE type_='PIANO_ROOM_CLASS' AND status_='COMPLETE' GROUP BY course_group_id_) cm ON cg.id_=cm.course_group_id_
- LEFT JOIN (SELECT course_group_id_,start_time_ FROM course_schedule WHERE type_='PIANO_ROOM_CLASS' GROUP BY course_group_id_) st ON cg.id_=st.course_group_id_
- WHERE cg.type_='PIANO_ROOM_CLASS'
- AND cg.teacher_id_=#{param.teacherId}
- <if test="param.search != null and param.search != ''">
- AND (
- cg.name_ LIKE concat('%',#{param.search},'%') OR
- cg.id_ LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.subjectId != null">
- AND cg.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.status != null and param.status != ''">
- AND cg.status_ = #{param.status}
- </if>
- </select>
- <select id="selectPianoGroupTeacherDetail"
- resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoDetailVo">
- SELECT * FROM (
- SELECT
- cs.id_ AS courseId,
- sb.id_ AS subjectId,
- sb.name_ AS subjectName,
- cs.teacher_id_ AS teacherId,
- tu.username_ AS teacherName,
- tu.real_name_ AS teacherRealName,
- cs.status_ AS `status`,
- a.studentCount AS studentCount,
- (cs.single_course_time_ * (a.studentCount+1)*(a.studentCount+1-1)) AS courseTime,
- cs.start_time_ AS startTime,
- cs.end_time_ AS endTime,
- p.user_id_ AS studentId,
- su.username_ AS studentName,
- su.real_name_ AS studentRealName,
- (CASE WHEN cs.start_time_ >= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
- (CASE WHEN cs.end_time_ <= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign,
- (CASE WHEN cs.start_time_ >= ta.sign_in_time_ AND cs.end_time_ <= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherSign
- FROM course_schedule cs
- LEFT JOIN course_group cg ON cs.course_group_id_ = cg.id_
- LEFT JOIN `subject` sb ON cg.subject_id_ = sb.id_
- LEFT JOIN sys_user tu ON cs.teacher_id_ = tu.id_
- LEFT JOIN (SELECT course_id_,COUNT(1) AS studentCount FROM course_schedule_student_payment WHERE course_type_='PIANO_ROOM_CLASS' GROUP BY course_id_) a ON cs.id_=a.course_id_
- LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
- LEFT JOIN student_attendance sa ON cs.id_=sa.course_schedule_id_
- LEFT JOIN course_schedule_student_payment p ON cs.id_=p.course_id_
- LEFT JOIN sys_user su ON cs.teacher_id_ = su.id_
- WHERE cs.type_='PIANO_ROOM_CLASS'
- AND cs.teacher_id_=#{param.teacherId}
- AND p.course_group_id_=#{param.courseGroupId}
- <if test="param.studentSign != null">
- AND cs.id_ IN
- <foreach collection="param.courseIds" item="item" open="(" close=")" separator=",">
- #{item}
- </foreach>
- </if>) m
- <where>
- <if test="param.search != null and param.search != ''">
- AND (
- courseId LIKE concat('%',#{param.search},'%') OR
- studentName LIKE concat('%',#{param.search},'%') OR
- studentId LIKE concat('%',#{param.search},'%')
- )
- </if>
- <if test="param.teacherSign != null">
- AND teacherSign = #{param.teacherSign}
- </if>
- <if test="param.status != null and param.status != ''">
- AND `status` = #{param.status}
- </if>
- <if test="param.startTime != null">
- AND startTime >= #{param.startTime}
- </if>
- <if test="param.endTime != null">
- AND endTime <= #{param.endTime}
- </if>
- </where>
- GROUP BY courseId
- </select>
- <select id="selectLiveSubject" resultType="com.yonge.cooleshow.biz.dal.entity.Subject">
- select distinct s.* from course_group cg
- left join subject s on cg.subject_id_ = s.id_
- where cg.status_ = 'APPLY' and cg.type_ = 'LIVE'
- </select>
- <select id="teacherCourseGroup"
- resultType="com.yonge.cooleshow.biz.dal.wrapper.course.CourseGroupWrapper$TeacherCourseGroupDto">
- select cg.name_ courseGroupName,cg.status_ status,
- cg.subject_id_ subjectId,
- cg.complete_course_num_ completeCourseNum,cg.course_num_ courseNum,
- cg.id_ courseGroupId,cg.course_plan_ coursePlan
- from (select * from (
- select cg.name_,cg.subject_id_,cg.complete_course_num_,cg.course_num_,
- cg.id_,cg.course_plan_,cg.teacher_id_,cg.type_,
- CASE WHEN cg.status_ = 'COMPLETE' THEN cg.status_ WHEN cs.status_ = 'NOT_START' THEN 'NOT_START' ELSE 'ING' END as status_
- from course_schedule cs
- left join course_group cg on cs.course_group_id_ = cg.id_
- order by cs.start_time_) cs
- group by cs.id_) cg
- <where>
- <if test="param.teacherId != null">
- AND cg.teacher_id_ = #{param.teacherId}
- </if>
- <if test="param.status != null and param.status != ''">
- AND cg.status_ = #{param.status}
- </if>
- <if test="param.subjectId != null">
- AND cg.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.courseGroupId != null">
- AND cg.id_ = #{param.courseGroupId}
- </if>
- <if test="param.courseType != null and param.courseType != ''">
- AND cg.type_ = #{param.courseType}
- </if>
- <if test="param.search != null and param.search != ''">
- AND cg.name_ LIKE concat('%',#{param.search},'%')
- </if>
- </where>
- </select>
- <select id="studentCourseGroup"
- resultType="com.yonge.cooleshow.biz.dal.wrapper.course.CourseGroupWrapper$StudentCourseGroupDto">
- select cg.name_ courseGroupName,cg.status_ status,
- cg.subject_id_ subjectId,
- cg.complete_course_num_ completeCourseNum,cg.course_num_ courseNum,
- cg.id_ courseGroupId,cg.course_plan_ coursePlan,cg.teacher_id_ teacherId
- from (select * from (
- select cg.name_,cg.subject_id_,cg.complete_course_num_,cg.course_num_,
- cg.id_,cg.course_plan_,cg.teacher_id_,cg.type_,
- CASE WHEN cg.status_ = 'COMPLETE' THEN cg.status_ WHEN cs.status_ = 'NOT_START' THEN 'NOT_START' ELSE 'ING' END as status_
- from course_schedule cs
- left join course_group cg on cs.course_group_id_ = cg.id_
- order by cs.start_time_) cs
- group by cs.id_) cg
- LEFT JOIN sys_user su ON cg.teacher_id_ = su.id_
- left join course_schedule_student_payment cssp ON cssp.course_group_id_ = cg.id_
- <where>
- <if test="param.teacherId != null">
- AND cg.teacher_id_ = #{param.teacherId}
- </if>
- <if test="param.studentId != null">
- AND cssp.user_id_ = #{param.studentId}
- </if>
- <if test="param.status != null and param.status != ''">
- AND cg.status_ = #{param.status}
- </if>
- <if test="param.subjectId != null">
- AND cg.subject_id_ = #{param.subjectId}
- </if>
- <if test="param.courseGroupId != null">
- AND cg.id_ = #{param.courseGroupId}
- </if>
- <if test="param.courseType != null and param.courseType != ''">
- AND cg.type_ = #{param.courseType}
- </if>
- <if test="param.search != null and param.search != ''">
- AND (cg.name_ LIKE concat('%',#{param.search},'%') OR su.username_ LIKE concat('%',#{param.search},'%'))
- </if>
- </where>
- GROUP BY cg.id_
- </select>
- </mapper>
|