CourseGroupMapper.xml 54 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3. <mapper namespace="com.yonge.cooleshow.biz.dal.dao.CourseGroupDao">
  4. <resultMap id="BaseResultMap" type="com.yonge.cooleshow.biz.dal.entity.CourseGroup">
  5. <id column="id_" jdbcType="BIGINT" property="id"/>
  6. <result column="type_" jdbcType="VARCHAR" property="type"/>
  7. <result column="teacher_id_" jdbcType="INTEGER" property="teacherId"/>
  8. <result column="name_" jdbcType="VARCHAR" property="name"/>
  9. <result column="subject_id_" jdbcType="INTEGER" property="subjectId"/>
  10. <result column="single_course_minutes_" jdbcType="INTEGER" property="singleCourseMinutes"/>
  11. <result column="course_num_" jdbcType="INTEGER" property="courseNum"/>
  12. <result column="complete_course_num_" jdbcType="INTEGER" property="completeCourseNum"/>
  13. <result column="course_introduce_" jdbcType="VARCHAR" property="courseIntroduce"/>
  14. <result column="course_price_" jdbcType="VARCHAR" property="coursePrice"/>
  15. <result column="status_" jdbcType="VARCHAR" property="status"/>
  16. <result column="sales_start_date_" jdbcType="TIMESTAMP" property="salesStartDate"/>
  17. <result column="sales_end_date_" jdbcType="TIMESTAMP" property="salesEndDate"/>
  18. <result column="background_pic_" jdbcType="VARCHAR" property="backgroundPic"/>
  19. <result column="mix_student_num_" jdbcType="INTEGER" property="mixStudentNum"/>
  20. <result column="max_student_num_" jdbcType="INTEGER" property="maxStudentNum"/>
  21. <result column="course_start_time_" jdbcType="TIMESTAMP" property="courseStartTime"/>
  22. <result column="course_end_time_" jdbcType="TIMESTAMP" property="courseEndTime"/>
  23. <result column="created_by_" jdbcType="INTEGER" property="createdBy"/>
  24. <result column="created_time_" jdbcType="TIMESTAMP" property="createdTime"/>
  25. <result column="updated_by_" jdbcType="INTEGER" property="updatedBy"/>
  26. <result column="updated_time_" jdbcType="TIMESTAMP" property="updatedTime"/>
  27. <result column="pre_student_num_" jdbcType="INTEGER" property="preStudentNum"/>
  28. <result column="im_group_id_" jdbcType="VARCHAR" property="imGroupId"/>
  29. <result column="reason_" jdbcType="VARCHAR" property="reason"/>
  30. <result column="course_plan_" jdbcType="VARCHAR" property="coursePlan"/>
  31. </resultMap>
  32. <sql id="Base_Column_List">
  33. id_
  34. , type_, teacher_id_, name_, subject_id_, single_course_minutes_, course_num_,
  35. complete_course_num_, course_introduce_, course_price_, status_, sales_start_date_,
  36. sales_end_date_, background_pic_, mix_student_num_,max_student_num_,pre_student_num_, im_group_id_,
  37. course_start_time_,course_end_time_, created_by_, created_time_, updated_by_, updated_time_,reason_,course_plan_
  38. </sql>
  39. <insert id="insertBatch" keyColumn="id_" keyProperty="id" useGeneratedKeys="true"
  40. parameterType="com.yonge.cooleshow.biz.dal.entity.CourseGroup">
  41. insert into course_group(type_, teacher_id_, name_, subject_id_, single_course_minutes_, course_num_,
  42. complete_course_num_, course_introduce_, course_price_, status_, sales_start_date_, sales_end_date_, background_pic_,
  43. mix_student_num_,max_student_num_,pre_student_num_,im_group_id_, course_start_time_, course_end_time_,
  44. created_by_, created_time_, updated_by_, updated_time_,reason_,course_plan_)
  45. values
  46. <foreach collection="entities" item="entity" separator=",">
  47. (#{entity.type}, #{entity.teacherId}, #{entity.name}, #{entity.subjectId}, #{entity.singleCourseMinutes},
  48. #{entity.courseNum}, #{entity.completeCourseNum}, #{entity.courseIntroduce}, #{entity.coursePrice}, #{entity.status},
  49. #{entity.salesStartDate}, #{entity.salesEndDate}, #{entity.backgroundPic}, #{entity.mixStudentNum},#{entity.maxStudentNum},
  50. #{entity.preStudentNum},#{entity.imGroupId},#{entity.courseStartTime},#{entity.courseEndTime}, #{entity.createdBy}, #{entity.createdTime}, #{entity.updatedBy},
  51. #{entity.updatedTime},#{entity.reason},#{entity.coursePlan})
  52. </foreach>
  53. </insert>
  54. <select id="queryTeacherCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVo">
  55. select distinct
  56. b.id_ as courseGroupId,
  57. b.name_ as courseGroupName,
  58. s.name_ as subjectName,
  59. b.teacher_id_ as teacherId,
  60. u.username_ as teacherName,
  61. b.course_start_time_ as courseStartTime,
  62. b.single_course_minutes_ as singleCourseMinutes,
  63. b.status_ as `status`,
  64. ifnull(b.pre_student_num_, 0) as studentCount,
  65. b.background_pic_ as backgroundPic,
  66. b.course_price_ as coursePrice,
  67. b.course_num_ as courseNum,
  68. u.avatar_ as avatar,
  69. b.sales_start_date_ as salesStartDate,
  70. b.sales_end_date_ as salesEndDate,
  71. b.mix_student_num_ as mixStudentNum,
  72. b.max_student_num_ as maxStudentNum,
  73. b.im_group_id_ as imGroupId,
  74. b.reason_ as reason,
  75. b.course_plan_ as coursePlan,
  76. b.course_introduce_ as courseIntroduce,
  77. 0 as existBuy
  78. from course_group as b
  79. left join subject as s on b.subject_id_ = s.id_
  80. left join sys_user as u on b.teacher_id_ = u.id_
  81. <where>
  82. u.del_flag_ = 0
  83. <if test="param.teacherId != null">
  84. and b.teacher_id_ = #{param.teacherId}
  85. </if>
  86. <if test="param.groupStatus != null">
  87. and b.status_ = #{param.groupStatus}
  88. </if>
  89. <if test="param.subjectId != null">
  90. AND b.subject_id_ = #{param.subjectId}
  91. </if>
  92. <if test="param.search != null and param.search !=''">
  93. and (
  94. u.username_ like concat('%',#{param.search},'%')
  95. or b.name_ like concat('%',#{param.search},'%')
  96. )
  97. </if>
  98. <if test="param.type != null and param.type != ''">
  99. and b.type_ = #{param.type}
  100. </if>
  101. </where>
  102. order by b.created_time_
  103. </select>
  104. <select id="queryStudentCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVo">
  105. select distinct b.id_ as courseGroupId,
  106. b.name_ as courseGroupName,
  107. s.name_ as subjectName,
  108. b.teacher_id_ as teacherId,
  109. u.username_ as teacherName,
  110. b.course_start_time_ as courseStartTime,
  111. b.single_course_minutes_ as singleCourseMinutes,
  112. b.status_ as `status`,
  113. ifnull(b.pre_student_num_, 0) as studentCount,
  114. b.background_pic_ as backgroundPic,
  115. b.course_price_ as coursePrice,
  116. b.course_num_ as courseNum,
  117. u.avatar_ as avatar,
  118. b.sales_start_date_ as salesStartDate,
  119. b.sales_end_date_ as salesEndDate,
  120. b.mix_student_num_ as mixStudentNum,
  121. b.max_student_num_ as maxStudentNum,
  122. b.im_group_id_ as imGroupId,
  123. b.reason_ as reason,
  124. b.course_plan_ as coursePlan,
  125. b.course_introduce_ as courseIntroduce,
  126. if(y.status_ = 'PAID', 1, 0) as existBuy
  127. from course_group as b
  128. left join subject as s on b.subject_id_ = s.id_
  129. left join sys_user as u on b.teacher_id_ = u.id_
  130. left join
  131. (select x.user_id_, x.course_group_id_, o.status_
  132. from course_schedule_student_payment as x
  133. left join user_order as o on x.order_no_ = o.order_no_ and x.user_id_ = o.user_id_
  134. left join user_order_detail as d on d.order_no_ = x.order_no_
  135. where x.user_id_ = #{param.studentId}) as y on b.id_ = y.course_group_id_
  136. <where>
  137. u.del_flag_ = 0
  138. <if test="param.teacherId != null">
  139. and b.teacher_id_ = #{param.teacherId}
  140. </if>
  141. <if test="param.groupStatus != null">
  142. and b.status_ = #{param.groupStatus}
  143. </if>
  144. <if test="param.subjectId != null">
  145. AND b.subject_id_ = #{param.subjectId}
  146. </if>
  147. <if test="param.search != null and param.search !=''">
  148. and (
  149. u.real_name_ like concat('%',#{param.search},'%')
  150. or b.name_ like concat('%',#{param.search},'%')
  151. )
  152. </if>
  153. <if test="param.auditVersion != null ">
  154. and #{param.auditVersion} = b.audit_version_
  155. </if>
  156. <if test="param.subjectId != null ">
  157. and #{param.subjectId} = b.subject_id_
  158. </if>
  159. <if test="param.type != null and param.type != ''">
  160. and b.type_ = #{param.type}
  161. </if>
  162. </where>
  163. </select>
  164. <select id="selectAdminLivePage" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
  165. select distinct
  166. cg.id_ as courseGroupId,
  167. cg.reason_ as reason,
  168. cg.name_ as name,
  169. cg.complete_course_num_ as endCourseNum,
  170. if(cg.complete_course_num_ = 0 ,cg.course_num_,cg.course_num_ - cg.complete_course_num_) as noStartCourseNum,
  171. cg.course_price_ as coursePrice,
  172. cg.pre_student_num_ as preStudentNum,
  173. cg.status_ as status,
  174. cg.course_num_ as courseNum,
  175. cg.created_time_ as createTime,
  176. cg.course_introduce_ as courseIntroduce,
  177. <if test="param.studentId != null">
  178. cssp.order_no_ as orderNo,
  179. </if>
  180. cg.im_group_id_ as imGroupId,
  181. cg.course_plan_ as coursePlan,
  182. su.username_ as teacherName,
  183. su.phone_ as phone,
  184. cg.teacher_id_ as teacherId
  185. from course_group cg
  186. left join sys_user su on su.id_ = cg. teacher_id_
  187. <if test="param.studentId != null">
  188. left join course_schedule_student_payment cssp on cg.id_ = cssp.course_group_id_
  189. </if>
  190. <where>
  191. <if test="param.teacherId != null">
  192. and #{param.teacherId} = cg.teacher_id_
  193. <if test="param.search != null and param.search !=''">
  194. and (cg.id_ = #{param.search} or cg.name_ like concat('%',#{param.search},'%'))
  195. </if>
  196. </if>
  197. <if test="param.studentId != null">
  198. and #{param.studentId} = cssp.user_id_
  199. <if test="param.search != null and param.search !=''">
  200. and (
  201. cg.id_ = #{param.search}
  202. or cg.name_ like concat('%',#{param.search},'%')
  203. or su.id_ = #{param.search}
  204. or su.username_ like concat('%',#{param.search},'%')
  205. or su.phone_ like concat('%',#{param.search},'%')
  206. )
  207. </if>
  208. <if test="param.orderNo != null and param.orderNo != ''">
  209. and cssp.order_no_ like concat('%',#{param.orderNo},'%')
  210. </if>
  211. </if>
  212. <if test="param.subjectId != null">
  213. and #{param.subjectId} = cg.subject_id_
  214. </if>
  215. <if test="param.status != null">
  216. and #{param.status} = cg.status_
  217. </if>
  218. <if test="param.startTime != null">
  219. and #{param.startTime} &lt;= cg.created_time_
  220. </if>
  221. <if test="param.endTime != null">
  222. and #{param.endTime} &gt;= cg.created_time_
  223. </if>
  224. <if test="param.courseType != null">
  225. and #{param.courseType} = cg.type_
  226. </if>
  227. </where>
  228. order by cg.id_ desc
  229. </select>
  230. <select id="selectCourseGroupSubject" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
  231. select
  232. cg.id_ as courseGroupId,
  233. s.name_ as subjectName
  234. from course_group cg
  235. left join subject s on cg.subject_id_ = s.id_
  236. <where>
  237. <if test="courseGroupIdList != null and courseGroupIdList.size() != 0">
  238. and cg.id_ in
  239. <foreach collection="courseGroupIdList" item="item" open="(" close=")" separator=",">
  240. #{item}
  241. </foreach>
  242. </if>
  243. </where>
  244. </select>
  245. <select id="selectAdminLiveStudentPage" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupStudentVo">
  246. select
  247. a.id_ as paymentId,
  248. su.id_ as studentId,
  249. su.username_ as studentName,
  250. a.actual_price_ as price,
  251. a.order_no_ as orderNo,
  252. su.phone_ as phone,
  253. a.create_time_ as payTime
  254. from user_order_detail as a
  255. left join user_order as o on a.order_no_ = o.order_no_
  256. left join sys_user as su on o.user_id_ = su.id_
  257. <where>
  258. o.status_ = 'PAID'
  259. <if test="param.courseGroupId != null">
  260. and #{param.courseGroupId} = a.biz_id_
  261. </if>
  262. <if test="param.search != null and param.search != ''">
  263. and (
  264. a.biz_id_ like concat('%',#{param.search},'%')
  265. or su.id_ like concat('%',#{param.search},'%')
  266. or su.username_ like concat('%',#{param.search},'%')
  267. or su.phone_ like concat('%',#{param.search},'%')
  268. )
  269. </if>
  270. <if test="param.orderNo != null and param.orderNo != ''">
  271. and a.order_no_ like concat('%',#{param.orderNo},'%')
  272. </if>
  273. <if test="param.startTime != null">
  274. and #{param.startTime} &lt;= a.create_time_
  275. </if>
  276. <if test="param.endTime != null">
  277. and #{param.endTime} &gt;= a.create_time_
  278. </if>
  279. </where>
  280. group by o.user_id_
  281. order by a.id_ desc
  282. </select>
  283. <select id="selectAdminLivePlan" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupPlanVo">
  284. select
  285. cs.id_ as courseId,
  286. cs.class_num_ as classNum,
  287. cs.class_date_ as classDate,
  288. cs.start_time_ as startTime,
  289. cs.end_time_ as endTime,
  290. cs.status_ as courseStatus,
  291. cp.plan_ as planInfo,
  292. lrv.url_ as videoUrl
  293. from course_schedule cs
  294. left join live_room_video lrv on cs.id_ = lrv.course_id_
  295. left join course_plan cp on cp.course_group_id_ = cs.course_group_id_ and cp.class_num_ = cs.class_num_
  296. <where>
  297. <if test="courseGroupId != null">
  298. and #{courseGroupId} = cs.course_group_id_
  299. </if>
  300. </where>
  301. order by cs.class_num_
  302. </select>
  303. <select id="selectAdminLiveCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
  304. select distinct
  305. cg.id_ as courseGroupId,
  306. cg.name_ as name,
  307. cg.complete_course_num_ as endCourseNum,
  308. if(cg.complete_course_num_ = 0 ,cg.course_num_,cg.course_num_ - cg.complete_course_num_) as noStartCourseNum,
  309. cg.course_price_ as coursePrice,
  310. cg.pre_student_num_ as preStudentNum,
  311. cg.status_ as status,
  312. cg.course_num_ as courseNum,
  313. cg.created_time_ as createTime,
  314. cg.course_introduce_ as courseIntroduce,
  315. cg.type_ as type,
  316. s.name_ as subjectName,
  317. cg.course_plan_ as coursePlan
  318. from course_group cg
  319. left join course_schedule_student_payment cssp on cg.id_ = cssp.course_group_id_
  320. left join subject s on cg.subject_id_ = s.id_
  321. <where>
  322. <if test="courseGroupId != null">
  323. and #{courseGroupId} = cg.id_
  324. </if>
  325. </where>
  326. </select>
  327. <select id="selectAdminLiveStudentCoursePage"
  328. resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupStudentCourseVo">
  329. select distinct
  330. cs.id_ as courseId,
  331. cs.class_date_ as classDate,
  332. cs.start_time_ as startTime,
  333. cs.end_time_ as endTime,
  334. cs.status_ as courseStatue,
  335. cssp.order_no_ as orderNo,
  336. sa.id_ as studentAttendanceId
  337. from course_schedule cs
  338. left join course_schedule_student_payment cssp on cs.id_ = cssp.course_id_ and #{param.studentId} = cssp.user_id_
  339. left join student_attendance sa on cs.id_ = sa.course_schedule_id_ and #{param.studentId} = sa.student_id_
  340. <where>
  341. cs.status_ != '${@com.yonge.cooleshow.biz.dal.enums.CourseScheduleEnum@CANCEL}'
  342. <if test="param.studentId != null">
  343. and cssp.user_id_ = #{param.studentId}
  344. </if>
  345. <if test="param.status != null">
  346. <choose>
  347. <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@TRUANT">
  348. and sa.id_ is null AND cs.status_ IN ('ING','COMPLETE')
  349. </when>
  350. <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@ATTENDCLASS">
  351. and sa.id_ is not null and #{param.studentId} = sa.student_id_
  352. </when>
  353. <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@NOTSTART">
  354. and cs.status_ = '${@ com.yonge.cooleshow.biz.dal.enums.CourseScheduleEnum@NOT_START}'
  355. </when>
  356. </choose>
  357. </if>
  358. <if test="param.courseGroupId != null">
  359. and #{param.courseGroupId} = cs.course_group_id_
  360. </if>
  361. <if test="param.courseId != null">
  362. and cs.id_ like concat('%',#{param.courseId},'%')
  363. </if>
  364. </where>
  365. order by cs.id_ desc
  366. </select>
  367. <select id="selectPracticeGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPracticeVo">
  368. SELECT
  369. cg.id_ AS groupId,
  370. cg.name_ AS groupName,
  371. cg.subject_id_ AS subjectId,
  372. sub.name_ AS subjectName,
  373. cg.course_num_ AS courseNum,
  374. IFNULL(cs.count_ ,0)AS completeCount,
  375. cg.teacher_id_ AS teacherId,
  376. tu.username_ AS teacherName,
  377. tu.real_name_ AS teacherRealName,
  378. sp.user_id_ AS studentId,
  379. su.username_ AS studentName,
  380. su.real_name_ AS studentRealName,
  381. cg.status_ AS `status`,
  382. cst.start_time_ AS startTime,
  383. cg.course_plan_ AS coursePlan
  384. FROM course_group cg
  385. LEFT JOIN `subject` sub ON cg.subject_id_=sub.id_
  386. LEFT JOIN sys_user tu ON cg.teacher_id_=tu.id_
  387. 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_
  388. LEFT JOIN sys_user su ON sp.user_id_=su.id_
  389. 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_
  390. 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_
  391. WHERE cg.type_=#{param.groupType} AND cg.status_ IN('ING','COMPLETE')
  392. <if test="param.search != null and param.search != ''">
  393. AND (
  394. cg.id_ LIKE concat('%',#{param.search},'%') OR
  395. cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  396. sp.user_id_ LIKE concat('%',#{param.search},'%') OR
  397. cg.name_ LIKE concat('%',#{param.search},'%') OR
  398. tu.username_ LIKE concat('%',#{param.search},'%') OR
  399. su.username_ LIKE concat('%',#{param.search},'%')
  400. )
  401. </if>
  402. <if test="param.subjectId != null">
  403. AND cg.subject_id_ = #{param.subjectId}
  404. </if>
  405. <if test="param.status != null and param.status != ''">
  406. AND cg.status_ = #{param.status}
  407. </if>
  408. <if test="param.studentId != null">
  409. AND sp.user_id_ = #{param.studentId}
  410. </if>
  411. <if test="param.teacherId != null">
  412. AND cg.teacher_id_ = #{param.teacherId}
  413. </if>
  414. </select>
  415. <select id="selectPracticeGroupDetail"
  416. resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPracticeDetailVo">
  417. SELECT * FROM
  418. (SELECT
  419. cs.id_ AS courseId,
  420. sb.name_ AS subjectName,
  421. cs.teacher_id_ AS teacherId,
  422. tu.username_ AS teacherName,
  423. tu.real_name_ AS teacherRealName,
  424. sp.user_id_ AS studentId,
  425. su.username_ AS studentName,
  426. su.real_name_ AS studentRealName,
  427. cs.status_ AS `status`,
  428. cs.start_time_ AS startTime,
  429. cs.end_time_ AS endTime,
  430. cs.class_date_ AS classDate,
  431. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
  432. (CASE WHEN cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign,
  433. (CASE WHEN cs.start_time_ &gt;= sa.sign_in_time_ THEN 1 ELSE 0 END) AS studentInSign,
  434. (CASE WHEN cs.end_time_ &lt;= sa.sign_out_time_ THEN 1 ELSE 0 END) AS studentOutSign,
  435. ts.status_ AS salaryStatus
  436. FROM course_schedule cs
  437. LEFT JOIN course_group cg ON cs.course_group_id_=cg.id_
  438. LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
  439. LEFT JOIN sys_user tu ON cs.teacher_id_=tu.id_
  440. LEFT JOIN course_schedule_student_payment sp ON cs.id_=sp.course_id_
  441. LEFT JOIN sys_user su ON sp.user_id_=su.id_
  442. LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
  443. LEFT JOIN student_attendance sa ON cs.id_=sa.course_schedule_id_
  444. LEFT JOIN course_schedule_teacher_salary ts ON cs.id_=ts.course_schedule_id_
  445. WHERE cs.lock_=0 AND cs.course_group_id_ = #{param.courseGroupId}) a
  446. <where>
  447. <if test="param.search != null and param.search != ''">
  448. AND (
  449. courseId LIKE concat('%',#{param.search},'%') OR
  450. teacherName LIKE concat('%',#{param.search},'%') OR
  451. teacherId LIKE concat('%',#{param.search},'%') OR
  452. studentName LIKE concat('%',#{param.search},'%') OR
  453. studentId LIKE concat('%',#{param.search},'%')
  454. )
  455. </if>
  456. <if test="param.teacherSign == 1">
  457. AND teacherInSign = #{param.teacherSign}
  458. </if>
  459. <if test="param.teacherSign == 0">
  460. AND teacherOutSign = #{param.teacherSign}
  461. </if>
  462. <if test="param.studentSign == 1">
  463. AND studentInSign = #{param.studentSign}
  464. </if>
  465. <if test="param.studentSign == 0">
  466. AND studentOutSign = #{param.studentSign}
  467. </if>
  468. <if test="param.status != null and param.status != ''">
  469. AND `status` = #{param.status}
  470. </if>
  471. <if test="param.salaryStatus != null and param.salaryStatus != ''">
  472. AND salaryStatus = #{param.salaryStatus}
  473. </if>
  474. <if test="param.startTime != null">
  475. AND classDate BETWEEN #{param.startTime} AND #{param.endTime}
  476. </if>
  477. <if test="param.studentId != null">
  478. AND studentId = #{param.studentId}
  479. </if>
  480. <if test="param.teacherId != null">
  481. AND teacherId = #{param.teacherId}
  482. </if>
  483. </where>
  484. </select>
  485. <select id="selectLiveGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupLiveVo">
  486. SELECT
  487. cg.id_ AS courseGroupId,
  488. cg.name_ AS courseGroupName,
  489. cg.subject_id_ AS subjectId,
  490. sb.name_ AS subjectName,
  491. cg.teacher_id_ AS teacherId,
  492. su.username_ AS teacherName,
  493. su.real_name_ AS teacherRealName,
  494. cg.course_num_ AS courseNum,
  495. cg.pre_student_num_ AS studentNum,
  496. cg.status_ AS `status`,
  497. IFNULL(cm.count_,0) AS completeCount,
  498. st.start_time_ AS startTime,
  499. cg.course_plan_ AS coursePlan
  500. FROM course_group cg
  501. LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
  502. LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
  503. 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_
  504. 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_
  505. <where>
  506. <if test="param.search != null and param.search != ''">
  507. AND (
  508. cg.id_ LIKE concat('%',#{param.search},'%') OR
  509. cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  510. cg.name_ LIKE concat('%',#{param.search},'%') OR
  511. su.username_ LIKE concat('%',#{param.search},'%')
  512. )
  513. </if>
  514. <if test="param.subjectId != null">
  515. AND cg.subject_id_ = #{param.subjectId}
  516. </if>
  517. <if test="param.groupType != null and param.groupType != ''">
  518. AND cg.type_ = #{param.groupType}
  519. </if>
  520. <if test="param.status != null and param.status != ''">
  521. AND cg.status_ = #{param.status}
  522. </if>
  523. </where>
  524. </select>
  525. <select id="selectLiveGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseSchedulePaymentVo">
  526. SELECT
  527. p.user_id_ AS studentId,
  528. u.username_ AS studentName,
  529. u.real_name_ AS studentRealName,
  530. u.phone_ AS studentPhone,
  531. p.actual_price_ AS actualPrice,
  532. p.order_no_ AS orderNo,
  533. o.create_time_ AS createdOrderTime
  534. FROM course_schedule_student_payment p
  535. LEFT JOIN sys_user u ON p.user_id_=u.id_
  536. LEFT JOIN user_order o ON p.order_no_ = o.order_no_
  537. WHERE p.course_group_id_=#{param.groupId}
  538. <if test="param.search != null and param.search != ''">
  539. AND (
  540. p.course_id_ LIKE concat('%',#{param.search},'%') OR
  541. p.user_id_ LIKE concat('%',#{param.search},'%') OR
  542. u.username_ LIKE concat('%',#{param.search},'%') OR
  543. u.phone_ LIKE concat('%',#{param.search},'%')
  544. )
  545. </if>
  546. <if test="param.orderNo != null and param.orderNo != ''">
  547. AND p.order_no_ = #{param.orderNo}
  548. </if>
  549. <if test="param.startTime != null">
  550. AND o.create_time_ &lt;= #{param.startTime}
  551. </if>
  552. <if test="param.endTime != null">
  553. AND o.create_time_ &gt;= #{param.endTime}
  554. </if>
  555. </select>
  556. <select id="selectLiveGroupPlan" resultType="com.yonge.cooleshow.biz.dal.vo.CourseSchedulePlanVo">
  557. SELECT
  558. distinct
  559. cs.id_ AS courseId,
  560. cp.plan_ AS courseIntroduce,
  561. cs.class_num_ AS classNum,
  562. cs.class_date_ AS classDate,
  563. cs.start_time_ AS startTime,
  564. cs.end_time_ AS endTime,
  565. ts.status_ AS salaryStatus,
  566. (select group_concat(lrv.url_) from live_room_video lrv where lrv.course_id_ = cs.id_)AS url,
  567. cs.status_ AS courseStatus,
  568. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
  569. (CASE WHEN cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign
  570. FROM course_schedule cs
  571. LEFT JOIN course_group g ON cs.course_group_id_=g.id_
  572. LEFT JOIN course_schedule_teacher_salary ts ON cs.id_=ts.course_schedule_id_
  573. LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
  574. left join course_plan cp on cp.course_group_id_ = cs.course_group_id_ and cp.class_num_ = cs.class_num_
  575. WHERE cs.course_group_id_= #{param.groupId}
  576. <if test="param.salaryStatus != null and param.salaryStatus != ''">
  577. AND ts.status_ = #{param.salaryStatus}
  578. </if>
  579. <if test="param.startTime != null">
  580. AND cs.class_date_ BETWEEN #{param.startTime} AND #{param.endTime}
  581. </if>
  582. <if test="param.search != null and param.search != ''">
  583. AND cs.id_ = #{param.search}
  584. </if>
  585. </select>
  586. <select id="selectVideoGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVideoVo">
  587. SELECT
  588. g.id_ AS groupId,
  589. g.lesson_name_ AS lessonName,
  590. g.lesson_subject_ AS subjectId,
  591. s.name_ AS subjectName,
  592. g.lesson_count_ AS lessonCount,
  593. IFNULL(p.count_,0) AS buyCount,
  594. g.teacher_id_ AS teacherId,
  595. u.username_ AS teacherName,
  596. g.pay_type_ AS payType,
  597. u.real_name_ AS teacherRealName,
  598. g.create_time_ AS createTime,
  599. g.shelves_time_ AS recordTime,
  600. g.shelves_flag_ as shelvesFlag,
  601. g.sort_number_ as sortNumber,
  602. g.top_flag_ as topFlag,
  603. g.audit_status_ as status,
  604. g.relation_type_ as relationType,
  605. g.draft_flag_ as draftFlag
  606. FROM video_lesson_group g
  607. LEFT JOIN `subject` s ON g.lesson_subject_=s.id_
  608. LEFT JOIN sys_user u ON g.teacher_id_=u.id_
  609. LEFT JOIN (
  610. SELECT video_lesson_group_id_,COUNT(1) AS count_ FROM video_lesson_purchase_record
  611. WHERE order_status_='PAID' GROUP BY video_lesson_group_id_) p ON g.id_=p.video_lesson_group_id_
  612. <where>
  613. <if test="param.search != null and param.search != ''">
  614. AND (
  615. g.id_ LIKE concat('%',#{param.search},'%') OR
  616. g.lesson_name_ LIKE concat('%',#{param.search},'%') OR
  617. g.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  618. u.username_ LIKE concat('%',#{param.search},'%')
  619. )
  620. </if>
  621. <if test="param.subjectId != null and param.subjectId != ''">
  622. AND g.lesson_subject_ = #{param.subjectId}
  623. </if>
  624. <if test="param.status != null and param.status != ''">
  625. AND g.audit_status_ = #{param.status}
  626. </if>
  627. <if test="param.shelvesFlag != null">
  628. AND g.shelves_flag_ = #{param.shelvesFlag}
  629. </if>
  630. <if test="param.draftFlag != null">
  631. AND g.draft_flag_ = #{param.draftFlag}
  632. </if>
  633. <if test="param.topFlag != null">
  634. AND g.top_flag_ = #{param.topFlag}
  635. </if>
  636. <if test="param.relationType != null">
  637. AND g.relation_type_ = #{param.relationType}
  638. </if>
  639. <if test="param.payType != null">
  640. AND g.pay_type_ = #{param.payType}
  641. </if>
  642. </where>
  643. order by g.top_flag_ desc ,g.sort_number_ desc,g.id_ desc
  644. </select>
  645. <select id="selectVideoGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupStudentVo">
  646. SELECT
  647. r.student_id_ AS studentId,
  648. u.username_ AS studentName,
  649. u.real_name_ AS studentRealName,
  650. u.phone_ AS studentPhone,
  651. r.order_no_ AS orderNo,
  652. r.pay_money_ AS payMoney,
  653. o.create_time_ AS createTime
  654. FROM video_lesson_purchase_record r
  655. LEFT JOIN sys_user u ON r.student_id_=u.id_
  656. LEFT JOIN user_order o ON r.order_no_=o.order_no_
  657. WHERE r.order_status_='PAID'
  658. AND video_lesson_group_id_ = #{param.groupId}
  659. <if test="param.search != null and param.search != ''">
  660. AND (
  661. r.student_id_ LIKE concat('%',#{param.search},'%') OR
  662. u.username_ LIKE concat('%',#{param.search},'%') OR
  663. u.phone_ LIKE concat('%',#{param.search},'%')
  664. )
  665. </if>
  666. <if test="param.orderNo != null and param.orderNo != ''">
  667. AND r.order_no_ = #{param.orderNo}
  668. </if>
  669. <if test="param.startTime != null">
  670. AND o.create_time_ &lt;= #{param.startTime}
  671. </if>
  672. <if test="param.endTime != null">
  673. AND o.create_time_ &gt;= #{param.endTime}
  674. </if>
  675. </select>
  676. <select id="selectVideoGroupPlan" resultType="com.yonge.cooleshow.biz.dal.entity.VideoLessonGroupDetail">
  677. SELECT
  678. id_ AS id,
  679. video_title_ AS videoTitle,
  680. video_content_ AS videoContent,
  681. video_url_ AS videoUrl,
  682. cover_url_ AS coverUrl
  683. FROM video_lesson_group_detail
  684. WHERE video_lesson_group_id_=#{param.groupId}
  685. </select>
  686. <select id="selectGroupInfoVo" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupInfoVo"
  687. parameterType="java.lang.Long">
  688. SELECT
  689. g.id_ AS id,
  690. g.name_ AS name,
  691. g.subject_id_ AS subjectId,
  692. s.name_ AS subjectName,
  693. g.course_num_ AS courseNum,
  694. g.course_price_ AS coursePrice,
  695. g.status_ AS `status`,
  696. g.course_introduce_ AS courseIntroduce,
  697. g.created_time_ AS createdTime,
  698. g.course_plan_ AS coursePlan
  699. FROM course_group g
  700. LEFT JOIN `subject` s ON g.subject_id_=s.id_
  701. WHERE g.id_ =#{groupId}
  702. </select>
  703. <update id="opsPreStudentNum">
  704. update course_group
  705. set
  706. pre_student_num_ = pre_student_num_ + #{num}
  707. where id_ = #{id}
  708. </update>
  709. <update id="updateBatch">
  710. UPDATE course_group
  711. SET status_='COMPLETE'
  712. WHERE id_ IN
  713. <foreach collection="list" item="item" open="(" separator="," close=")">
  714. #{item}
  715. </foreach>
  716. </update>
  717. <update id="updateCompleteCourseNum">
  718. update course_group cg
  719. left join (
  720. select cs.course_group_id_,COUNT(cs.id_) num_ from course_schedule cs
  721. where cs.course_group_id_ IN
  722. <foreach collection="groupIds" item="item" open="(" separator="," close=")">
  723. #{item}
  724. </foreach>
  725. AND cs.status_ = 'COMPLETE'
  726. group by cs.course_group_id_) cs ON cs.course_group_id_ = cg.id_
  727. set cg.complete_course_num_ = cs.num_
  728. where cs.course_group_id_ = cg.id_
  729. </update>
  730. <update id="updateExposureNum">
  731. update course_group
  732. set exposure_num_ = exposure_num_ + #{exposureNum}
  733. where id_ = #{groupId}
  734. </update>
  735. <select id="selectPianoGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
  736. SELECT
  737. cg.id_ AS courseGroupId,
  738. cg.name_ AS courseGroupName,
  739. cg.subject_id_ AS subjectId,
  740. sb.name_ AS subjectName,
  741. cg.teacher_id_ AS teacherId,
  742. su.username_ AS teacherName,
  743. su.real_name_ AS teacherRealName,
  744. cg.course_num_ AS courseNum,
  745. cg.status_ AS `status`,
  746. cg.course_plan_ AS coursePlan,
  747. IFNULL(cm.count_,0) AS completeCount,
  748. st.start_time_ AS startTime
  749. FROM course_group cg
  750. LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
  751. LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
  752. 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_
  753. 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_
  754. WHERE cg.type_='PIANO_ROOM_CLASS'
  755. <if test="param.search != null and param.search != ''">
  756. AND (
  757. cg.id_ LIKE concat('%',#{param.search},'%') OR
  758. cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  759. cg.name_ LIKE concat('%',#{param.search},'%') OR
  760. su.username_ LIKE concat('%',#{param.search},'%')
  761. )
  762. </if>
  763. <if test="param.subjectId != null">
  764. AND cg.subject_id_ = #{param.subjectId}
  765. </if>
  766. <if test="param.status != null and param.status != ''">
  767. AND cg.status_ = #{param.status}
  768. </if>
  769. order by st.start_time_ desc,cg.id_ desc
  770. </select>
  771. <select id="selectPianoGroupDetail"
  772. resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoDetailVo">
  773. SELECT
  774. cs.id_ AS courseId,
  775. sb.id_ AS subjectId,
  776. sb.name_ AS subjectName,
  777. cs.teacher_id_ AS teacherId,
  778. tu.username_ AS teacherName,
  779. tu.real_name_ AS teacherRealName,
  780. cs.status_ AS `status`,
  781. a.studentCount AS studentCount,
  782. (cs.single_course_time_ * (a.studentCount+1)*(a.studentCount+1-1)) AS courseTime,
  783. cs.start_time_ AS startTime,
  784. cs.end_time_ AS endTime,
  785. b.teacherInSign AS teacherInSign,
  786. b.teacherOutSign AS teacherOutSign
  787. FROM course_schedule cs
  788. LEFT JOIN course_group cg ON cs.course_group_id_ = cg.id_
  789. LEFT JOIN `subject` sb ON cg.subject_id_ = sb.id_
  790. LEFT JOIN sys_user tu ON cs.teacher_id_ = tu.id_
  791. 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_
  792. LEFT JOIN (SELECT cs.id_ AS cid,( CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ THEN 1 ELSE 0 END ) AS teacherInSign,( CASE WHEN cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END ) AS teacherOutSign
  793. 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
  794. WHERE cs.type_='PIANO_ROOM_CLASS'
  795. AND cs.course_group_id_=#{param.courseGroupId}
  796. <if test="param.search != null and param.search != ''">
  797. AND cs.id_ LIKE concat('%',#{param.search},'%')
  798. </if>
  799. <if test="param.status != null and param.status != ''">
  800. AND cs.status_ = #{param.status}
  801. </if>
  802. <if test="param.startTime != null">
  803. AND cs.start_time_ &gt;= #{param.startTime}
  804. </if>
  805. <if test="param.endTime != null">
  806. AND cs.start_time_ &lt;= #{param.endTime}
  807. </if>
  808. <if test="param.teacherSign == 1">
  809. AND b.teacherInSign = #{param.teacherSign}
  810. </if>
  811. <if test="param.teacherSign == 0">
  812. AND b.teacherOutSign = #{param.teacherSign}
  813. </if>
  814. <if test="param.studentSign != null">
  815. AND cs.id_ IN
  816. <foreach collection="param.courseIds" item="item" open="(" close=")" separator=",">
  817. #{item}
  818. </foreach>
  819. </if>
  820. </select>
  821. <select id="studentSign" resultType="com.yonge.cooleshow.biz.dal.vo.StudentSignVo">
  822. SELECT DISTINCT
  823. p.course_id_ AS courseId,
  824. p.user_id_ AS userId,
  825. u.username_ AS userName,
  826. u.real_name_ AS realName,
  827. ( CASE WHEN c.start_time_ &gt;= a.sign_in_time_ THEN 1 ELSE 0 END ) AS studentInSign,
  828. ( CASE WHEN c.end_time_ &lt;= a.sign_out_time_ THEN 1 ELSE 0 END ) AS studentOutSign
  829. FROM course_schedule_student_payment p
  830. LEFT JOIN sys_user u ON p.user_id_=u.id_
  831. LEFT JOIN course_schedule c ON p.course_id_=c.id_
  832. LEFT JOIN student_attendance a ON p.user_id_=a.student_id_ and a.course_schedule_id_ = c.id_
  833. <where>
  834. <if test="courseId !=null">
  835. AND p.course_id_=#{courseId}
  836. </if>
  837. <if test="type !=null and type!=''">
  838. AND p.course_type_=#{type}
  839. </if>
  840. </where>
  841. </select>
  842. <select id="selectPianoGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
  843. SELECT DISTINCT
  844. g.id_ AS courseGroupId,
  845. g.name_ AS courseGroupName,
  846. s.id_ AS subjectId,
  847. s.name_ AS subjectName,
  848. g.teacher_id_ AS teacherId,
  849. u.username_ AS teacherName,
  850. u.real_name_ AS teacherRealName,
  851. g.course_num_ AS courseNum,
  852. IFNULL(cm.count_,0) AS completeCount,
  853. g.status_ AS `status`,
  854. st.start_time_ AS startTime
  855. FROM course_schedule_student_payment p
  856. LEFT JOIN course_group g ON p.course_group_id_=g.id_
  857. LEFT JOIN `subject` s ON g.subject_id_=s.id_
  858. LEFT JOIN sys_user u ON g.teacher_id_=u.id_
  859. 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_
  860. 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_
  861. WHERE p.course_type_='PIANO_ROOM_CLASS'
  862. AND p.user_id_=#{param.studentId}
  863. <if test="param.search != null and param.search != ''">
  864. AND (
  865. g.id_ LIKE concat('%',#{param.search},'%') OR
  866. g.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  867. u.username_ LIKE concat('%',#{param.search},'%') OR
  868. g.name_ LIKE concat('%',#{param.search},'%')
  869. )
  870. </if>
  871. <if test="param.subjectId != null">
  872. AND s.id_ = #{param.subjectId}
  873. </if>
  874. <if test="param.status != null and param.status != ''">
  875. AND g.status_ = #{param.status}
  876. </if>
  877. </select>
  878. <select id="selectPianoGroupStudentDetail"
  879. resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoDetailVo">
  880. SELECT * FROM (
  881. SELECT
  882. cs.id_ AS courseId,
  883. sb.id_ AS subjectId,
  884. sb.name_ AS subjectName,
  885. cs.teacher_id_ AS teacherId,
  886. tu.username_ AS teacherName,
  887. tu.real_name_ AS teacherRealName,
  888. cs.status_ AS `status`,
  889. a.studentCount AS studentCount,
  890. (cs.single_course_time_ * (a.studentCount+1)*(a.studentCount+1-1)) AS courseTime,
  891. cs.start_time_ AS startTime,
  892. cs.end_time_ AS endTime,
  893. p.user_id_ AS studentId,
  894. su.username_ AS studentName,
  895. su.real_name_ AS studentRealName,
  896. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
  897. (CASE WHEN cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign,
  898. (CASE WHEN cs.start_time_ &gt;= sa.sign_in_time_ THEN 1 ELSE 0 END) AS studentInSign,
  899. (CASE WHEN cs.end_time_ &lt;= sa.sign_out_time_ THEN 1 ELSE 0 END) AS studentOutSign,
  900. (CASE WHEN cs.start_time_ &gt;= sa.sign_in_time_ AND cs.end_time_ &lt;= sa.sign_out_time_ THEN 1 ELSE 0 END) AS studentSign,
  901. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ AND cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherSign
  902. FROM course_schedule cs
  903. LEFT JOIN course_group cg ON cs.course_group_id_ = cg.id_
  904. LEFT JOIN `subject` sb ON cg.subject_id_ = sb.id_
  905. LEFT JOIN sys_user tu ON cs.teacher_id_ = tu.id_
  906. 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_
  907. LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
  908. LEFT JOIN student_attendance sa ON cs.id_=sa.course_schedule_id_
  909. LEFT JOIN course_schedule_student_payment p ON cs.id_=p.course_id_
  910. LEFT JOIN sys_user su ON p.user_id_ = su.id_
  911. WHERE cs.type_='PIANO_ROOM_CLASS'
  912. AND p.user_id_=#{param.studentId}
  913. AND p.course_group_id_=#{param.courseGroupId}) m
  914. <where>
  915. <if test="param.search != null and param.search != ''">
  916. AND courseId LIKE concat('%',#{param.search},'%')
  917. </if>
  918. <if test="param.studentSign != null">
  919. AND studentSign = #{param.studentSign}
  920. </if>
  921. <if test="param.teacherSign != null">
  922. AND teacherSign = #{param.teacherSign}
  923. </if>
  924. <if test="param.status != null and param.status != ''">
  925. AND `status` = #{param.status}
  926. </if>
  927. <if test="param.startTime != null">
  928. AND startTime &gt;= #{param.startTime}
  929. </if>
  930. <if test="param.endTime != null">
  931. AND startTime &lt;= #{param.endTime}
  932. </if>
  933. </where>
  934. </select>
  935. <select id="selectPianoGroupTeacher" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
  936. SELECT
  937. cg.id_ AS courseGroupId,
  938. cg.name_ AS courseGroupName,
  939. cg.subject_id_ AS subjectId,
  940. sb.name_ AS subjectName,
  941. cg.teacher_id_ AS teacherId,
  942. su.username_ AS teacherName,
  943. su.real_name_ AS teacherRealName,
  944. cg.course_num_ AS courseNum,
  945. cg.status_ AS `status`,
  946. IFNULL(cm.count_,0) AS completeCount,
  947. cg.course_plan_ AS coursePlan,
  948. st.start_time_ AS startTime
  949. FROM course_group cg
  950. LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
  951. LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
  952. 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_
  953. 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_
  954. WHERE cg.type_='PIANO_ROOM_CLASS'
  955. AND cg.teacher_id_=#{param.teacherId}
  956. <if test="param.search != null and param.search != ''">
  957. AND (
  958. cg.name_ LIKE concat('%',#{param.search},'%') OR
  959. cg.id_ LIKE concat('%',#{param.search},'%')
  960. )
  961. </if>
  962. <if test="param.subjectId != null">
  963. AND cg.subject_id_ = #{param.subjectId}
  964. </if>
  965. <if test="param.status != null and param.status != ''">
  966. AND cg.status_ = #{param.status}
  967. </if>
  968. </select>
  969. <select id="selectPianoGroupTeacherDetail"
  970. resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoDetailVo">
  971. SELECT * FROM (
  972. SELECT
  973. cs.id_ AS courseId,
  974. sb.id_ AS subjectId,
  975. sb.name_ AS subjectName,
  976. cs.teacher_id_ AS teacherId,
  977. tu.username_ AS teacherName,
  978. tu.real_name_ AS teacherRealName,
  979. cs.status_ AS `status`,
  980. a.studentCount AS studentCount,
  981. (cs.single_course_time_ * (a.studentCount+1)*(a.studentCount+1-1)) AS courseTime,
  982. cs.start_time_ AS startTime,
  983. cs.end_time_ AS endTime,
  984. p.user_id_ AS studentId,
  985. su.username_ AS studentName,
  986. su.real_name_ AS studentRealName,
  987. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
  988. (CASE WHEN cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign,
  989. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ AND cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherSign
  990. FROM course_schedule cs
  991. LEFT JOIN course_group cg ON cs.course_group_id_ = cg.id_
  992. LEFT JOIN `subject` sb ON cg.subject_id_ = sb.id_
  993. LEFT JOIN sys_user tu ON cs.teacher_id_ = tu.id_
  994. 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_
  995. LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
  996. LEFT JOIN student_attendance sa ON cs.id_=sa.course_schedule_id_
  997. LEFT JOIN course_schedule_student_payment p ON cs.id_=p.course_id_
  998. LEFT JOIN sys_user su ON cs.teacher_id_ = su.id_
  999. WHERE cs.type_='PIANO_ROOM_CLASS'
  1000. AND cs.teacher_id_=#{param.teacherId}
  1001. AND p.course_group_id_=#{param.courseGroupId}
  1002. <if test="param.studentSign != null">
  1003. AND cs.id_ IN
  1004. <foreach collection="param.courseIds" item="item" open="(" close=")" separator=",">
  1005. #{item}
  1006. </foreach>
  1007. </if>) m
  1008. <where>
  1009. <if test="param.search != null and param.search != ''">
  1010. AND (
  1011. courseId LIKE concat('%',#{param.search},'%') OR
  1012. studentName LIKE concat('%',#{param.search},'%') OR
  1013. studentId LIKE concat('%',#{param.search},'%')
  1014. )
  1015. </if>
  1016. <if test="param.teacherSign != null">
  1017. AND teacherSign = #{param.teacherSign}
  1018. </if>
  1019. <if test="param.status != null and param.status != ''">
  1020. AND `status` = #{param.status}
  1021. </if>
  1022. <if test="param.startTime != null">
  1023. AND startTime &gt;= #{param.startTime}
  1024. </if>
  1025. <if test="param.endTime != null">
  1026. AND endTime &lt;= #{param.endTime}
  1027. </if>
  1028. </where>
  1029. GROUP BY courseId
  1030. </select>
  1031. <select id="selectLiveSubject" resultType="com.yonge.cooleshow.biz.dal.entity.Subject">
  1032. select distinct s.* from course_group cg
  1033. left join subject s on cg.subject_id_ = s.id_
  1034. where cg.status_ = 'APPLY' and cg.type_ = 'LIVE'
  1035. </select>
  1036. <select id="teacherCourseGroup"
  1037. resultType="com.yonge.cooleshow.biz.dal.wrapper.course.CourseGroupWrapper$TeacherCourseGroupDto">
  1038. select cg.name_ courseGroupName,cg.status_ status,
  1039. cg.subject_id_ subjectId,
  1040. cg.complete_course_num_ completeCourseNum,cg.course_num_ courseNum,
  1041. cg.id_ courseGroupId,cg.course_plan_ coursePlan
  1042. from (select * from (
  1043. select cg.name_,cg.subject_id_,cg.complete_course_num_,cg.course_num_,
  1044. cg.id_,cg.course_plan_,cg.teacher_id_,cg.type_,
  1045. CASE WHEN cg.status_ = 'COMPLETE' THEN cg.status_ WHEN cs.status_ = 'NOT_START' THEN 'NOT_START' ELSE 'ING' END as status_
  1046. from course_schedule cs
  1047. left join course_group cg on cs.course_group_id_ = cg.id_
  1048. order by cs.start_time_) cs
  1049. group by cs.id_) cg
  1050. <where>
  1051. <if test="param.teacherId != null">
  1052. AND cg.teacher_id_ = #{param.teacherId}
  1053. </if>
  1054. <if test="param.status != null and param.status != ''">
  1055. AND cg.status_ = #{param.status}
  1056. </if>
  1057. <if test="param.subjectId != null">
  1058. AND cg.subject_id_ = #{param.subjectId}
  1059. </if>
  1060. <if test="param.courseGroupId != null">
  1061. AND cg.id_ = #{param.courseGroupId}
  1062. </if>
  1063. <if test="param.courseType != null and param.courseType != ''">
  1064. AND cg.type_ = #{param.courseType}
  1065. </if>
  1066. <if test="param.search != null and param.search != ''">
  1067. AND cg.name_ LIKE concat('%',#{param.search},'%')
  1068. </if>
  1069. </where>
  1070. GROUP BY cg.id_ DESC
  1071. </select>
  1072. <select id="studentCourseGroup"
  1073. resultType="com.yonge.cooleshow.biz.dal.wrapper.course.CourseGroupWrapper$StudentCourseGroupDto">
  1074. select cg.name_ courseGroupName,cg.status_ status,
  1075. cg.subject_id_ subjectId,
  1076. cg.complete_course_num_ completeCourseNum,cg.course_num_ courseNum,
  1077. cg.id_ courseGroupId,cg.course_plan_ coursePlan,cg.teacher_id_ teacherId
  1078. from (select * from (
  1079. select cg.name_,cg.subject_id_,cg.complete_course_num_,cg.course_num_,
  1080. cg.id_,cg.course_plan_,cg.teacher_id_,cg.type_,
  1081. CASE WHEN cg.status_ = 'COMPLETE' THEN cg.status_ WHEN cs.status_ = 'NOT_START' THEN 'NOT_START' ELSE 'ING' END as status_
  1082. from course_schedule cs
  1083. left join course_group cg on cs.course_group_id_ = cg.id_
  1084. order by cs.start_time_) cs
  1085. group by cs.id_) cg
  1086. LEFT JOIN sys_user su ON cg.teacher_id_ = su.id_
  1087. left join course_schedule_student_payment cssp ON cssp.course_group_id_ = cg.id_
  1088. <where>
  1089. <if test="param.teacherId != null">
  1090. AND cg.teacher_id_ = #{param.teacherId}
  1091. </if>
  1092. <if test="param.studentId != null">
  1093. AND cssp.user_id_ = #{param.studentId}
  1094. </if>
  1095. <if test="param.status != null and param.status != ''">
  1096. AND cg.status_ = #{param.status}
  1097. </if>
  1098. <if test="param.subjectId != null">
  1099. AND cg.subject_id_ = #{param.subjectId}
  1100. </if>
  1101. <if test="param.courseGroupId != null">
  1102. AND cg.id_ = #{param.courseGroupId}
  1103. </if>
  1104. <if test="param.courseType != null and param.courseType != ''">
  1105. AND cg.type_ = #{param.courseType}
  1106. </if>
  1107. <if test="param.search != null and param.search != ''">
  1108. AND (cg.name_ LIKE concat('%',#{param.search},'%') OR su.username_ LIKE concat('%',#{param.search},'%'))
  1109. </if>
  1110. </where>
  1111. GROUP BY cg.id_ DESC
  1112. </select>
  1113. <update id="updateLockNum">
  1114. update course_group
  1115. set lock_num_ = lock_num_ + #{num}
  1116. where id_ = #{groupId} and lock_num_ + #{num} &lt;= max_student_num_ and lock_num_ + #{num} &gt;= 0
  1117. </update>
  1118. <update id="updateCourseStartTime">
  1119. update course_group cg
  1120. left join (
  1121. select course_group_id_,MIN(start_time_) start_time_,MAX(end_time_) end_time_ from course_schedule
  1122. where course_group_id_ = #{groupId}
  1123. group by course_group_id_) c ON c.course_group_id_ = cg.id_
  1124. set cg.course_start_time_ = c.start_time_,cg.course_end_time_ = c.end_time_
  1125. where c.course_group_id_ = cg.id_ AND cg.id_ = #{groupId}
  1126. </update>
  1127. </mapper>