CourseGroupMapper.xml 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802
  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="course_start_time_" jdbcType="TIMESTAMP" property="courseStartTime"/>
  21. <result column="created_by_" jdbcType="INTEGER" property="createdBy"/>
  22. <result column="created_time_" jdbcType="TIMESTAMP" property="createdTime"/>
  23. <result column="updated_by_" jdbcType="INTEGER" property="updatedBy"/>
  24. <result column="updated_time_" jdbcType="TIMESTAMP" property="updatedTime"/>
  25. <result column="pre_student_num_" jdbcType="INTEGER" property="preStudentNum"/>
  26. <result column="im_group_id_" jdbcType="VARCHAR" property="imGroupId"/>
  27. </resultMap>
  28. <sql id="Base_Column_List">
  29. id_
  30. , 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_,pre_student_num_, im_group_id_, course_start_time_, created_by_, created_time_, updated_by_, updated_time_
  31. </sql>
  32. <insert id="insertBatch" keyColumn="id_" keyProperty="id" useGeneratedKeys="true"
  33. parameterType="com.yonge.cooleshow.biz.dal.entity.CourseGroup">
  34. insert into course_group(type_, teacher_id_, name_, subject_id_, single_course_minutes_, course_num_,
  35. complete_course_num_, course_introduce_, course_price_, status_, sales_start_date_, sales_end_date_, background_pic_,
  36. mix_student_num_,pre_student_num_,im_group_id_, course_start_time_, created_by_, created_time_, updated_by_, updated_time_)
  37. values
  38. <foreach collection="entities" item="entity" separator=",">
  39. (#{entity.type}, #{entity.teacherId}, #{entity.name}, #{entity.subjectId}, #{entity.singleCourseMinutes},
  40. #{entity.courseNum}, #{entity.completeCourseNum}, #{entity.courseIntroduce}, #{entity.coursePrice}, #{entity.status},
  41. #{entity.salesStartDate}, #{entity.salesEndDate}, #{entity.backgroundPic}, #{entity.mixStudentNum},
  42. #{entity.preStudentNum},#{entity.imGroupId},#{entity.courseStartTime}, #{entity.createdBy}, #{entity.createdTime}, #{entity.updatedBy},
  43. #{entity.updatedTime})
  44. </foreach>
  45. </insert>
  46. <select id="queryTeacherCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVo">
  47. select distinct
  48. b.id_ as courseGroupId,
  49. b.name_ as courseGroupName,
  50. s.name_ as subjectName,
  51. b.teacher_id_ as teacherId,
  52. u.username_ as teacherName,
  53. b.course_start_time_ as courseStartTime,
  54. b.single_course_minutes_ as singleCourseMinutes,
  55. b.status_ as `status`,
  56. ifnull(b.pre_student_num_, 0) as studentCount,
  57. b.background_pic_ as backgroundPic,
  58. b.course_price_ as coursePrice,
  59. b.course_num_ as courseNum,
  60. u.avatar_ as avatar,
  61. b.sales_start_date_ as salesStartDate,
  62. b.sales_end_date_ as salesEndDate,
  63. b.mix_student_num_ as mixStudentNum,
  64. b.im_group_id_ as imGroupId,
  65. 0 as existBuy
  66. from course_group as b
  67. left join subject as s on b.subject_id_ = s.id_
  68. left join sys_user as u on b.teacher_id_ = u.id_
  69. <where>
  70. <if test="param.teacherId != null">
  71. and b.teacher_id_ = #{param.teacherId}
  72. </if>
  73. <if test="param.groupStatus != null">
  74. and b.status_ = #{param.groupStatus}
  75. </if>
  76. <if test="param.subjectId != null">
  77. AND b.subject_id_ = #{param.subjectId}
  78. </if>
  79. <if test="param.search != null and param.search !=''">
  80. and (
  81. u.real_name_ like concat('%',#{param.search},'%')
  82. or b.name_ like concat('%',#{param.search},'%')
  83. )
  84. </if>
  85. <if test="param.type != null and param.type != ''">
  86. and b.type_ = #{param.type}
  87. </if>
  88. </where>
  89. </select>
  90. <select id="queryStudentCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVo">
  91. select distinct b.id_ as courseGroupId,
  92. b.name_ as courseGroupName,
  93. s.name_ as subjectName,
  94. b.teacher_id_ as teacherId,
  95. u.username_ as teacherName,
  96. b.course_start_time_ as courseStartTime,
  97. b.single_course_minutes_ as singleCourseMinutes,
  98. b.status_ as `status`,
  99. ifnull(b.pre_student_num_, 0) as studentCount,
  100. b.background_pic_ as backgroundPic,
  101. b.course_price_ as coursePrice,
  102. b.course_num_ as courseNum,
  103. u.avatar_ as avatar,
  104. b.sales_start_date_ as salesStartDate,
  105. b.sales_end_date_ as salesEndDate,
  106. b.mix_student_num_ as mixStudentNum,
  107. b.im_group_id_ as imGroupId,
  108. if(y.status_ = 'PAID', 1, 0) as existBuy
  109. from course_group as b
  110. left join subject as s on b.subject_id_ = s.id_
  111. left join sys_user as u on b.teacher_id_ = u.id_
  112. left join
  113. (select x.user_id_, x.course_group_id_, o.status_
  114. from course_schedule_student_payment as x
  115. left join user_order as o on x.order_no_ = o.order_no_ and x.user_id_ = o.user_id_
  116. left join user_order_detail as d on d.order_no_ = x.order_no_
  117. where x.user_id_ = #{param.studentId}) as y on b.id_ = y.course_group_id_
  118. <where>
  119. <if test="param.teacherId != null">
  120. and b.teacher_id_ = #{param.teacherId}
  121. </if>
  122. <if test="param.groupStatus != null">
  123. and b.status_ = #{param.groupStatus}
  124. </if>
  125. <if test="param.subjectId != null">
  126. AND b.subject_id_ = #{param.subjectId}
  127. </if>
  128. <if test="param.search != null and param.search !=''">
  129. and (
  130. u.real_name_ like concat('%',#{param.search},'%')
  131. or b.name_ like concat('%',#{param.search},'%')
  132. )
  133. </if>
  134. <if test="param.auditVersion != null ">
  135. and #{param.auditVersion} = b.audit_version_
  136. </if>
  137. <if test="param.subjectId != null ">
  138. and #{param.subjectId} = b.subject_id_
  139. </if>
  140. </where>
  141. </select>
  142. <select id="selectAdminLivePage" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
  143. select distinct
  144. cg.id_ as courseGroupId,
  145. cg.name_ as name,
  146. cg.complete_course_num_ as endCourseNum,
  147. if(cg.complete_course_num_ = 0 ,cg.course_num_,cg.course_num_ - cg.complete_course_num_) as noStartCourseNum,
  148. cg.course_price_ as coursePrice,
  149. cg.pre_student_num_ as preStudentNum,
  150. cg.status_ as status,
  151. cg.course_num_ as courseNum,
  152. cg.created_time_ as createTime,
  153. cg.course_introduce_ as courseIntroduce,
  154. <if test="param.studentId != null">
  155. cssp.order_no_ as orderNo,
  156. </if>
  157. cg.im_group_id_ as imGroupId
  158. from course_group cg
  159. left join course_schedule_student_payment cssp on cg.id_ = cssp.course_group_id_
  160. left join sys_user su on su.id_ = cssp.user_id_
  161. <where>
  162. <if test="param.teacherId != null">
  163. and #{param.teacherId} = cg.teacher_id_
  164. </if>
  165. <if test="param.studentId != null">
  166. and #{param.studentId} = cssp.user_id_
  167. </if>
  168. <if test="param.search != null and param.search !=''">
  169. and (
  170. cg.id_ like concat('%',#{param.search},'%')
  171. or su.id_ like concat('%',#{param.search},'%')
  172. or su.username_ like concat('%',#{param.search},'%')
  173. or su.phone_ like concat('%',#{param.search},'%')
  174. )
  175. </if>
  176. <if test="param.orderNo != null and param.orderNo != ''">
  177. and cssp.order_no_ like concat('%',#{param.orderNo},'%')
  178. </if>
  179. <if test="param.subjectId != null">
  180. and #{param.subjectId} = cg.subject_id_
  181. </if>
  182. <if test="param.status != null">
  183. and #{param.status} = cg.status_
  184. </if>
  185. <if test="param.startTime != null">
  186. and #{param.startTime} &lt;= cg.created_time_
  187. </if>
  188. <if test="param.endTime != null">
  189. and #{param.endTime} &gt;= cg.created_time_
  190. </if>
  191. <if test="param.courseType != null">
  192. and #{param.courseType} = cg.type_
  193. </if>
  194. </where>
  195. order by cg.id_ desc
  196. </select>
  197. <select id="selectCourseGroupSubject" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
  198. select
  199. cg.id_ as courseGroupId,
  200. s.name_ as subjectName
  201. from course_group cg
  202. left join subject s on cg.subject_id_ = s.id_
  203. <where>
  204. <if test="courseGroupIdList != null and courseGroupIdList.size() != 0">
  205. and cg.id_ in
  206. <foreach collection="courseGroupIdList" item="item" open="(" close=")" separator=",">
  207. #{item}
  208. </foreach>
  209. </if>
  210. </where>
  211. </select>
  212. <select id="selectAdminLiveStudentPage" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupStudentVo">
  213. select
  214. cssp.id_ as paymentId,
  215. su.id_ as studentId,
  216. su.username_ as studentName,
  217. cssp.actual_price_ as price,
  218. cssp.order_no_ as orderNo,
  219. su.phone_ as phone,
  220. cssp.created_time_ as payTime
  221. from course_schedule_student_payment cssp
  222. left join sys_user su on cssp.user_id_ = su.id_
  223. <where>
  224. <if test="param.courseGroupId != null">
  225. and #{param.courseGroupId} = cssp.course_group_id_
  226. </if>
  227. <if test="param.search != null and param.search != ''">
  228. and (
  229. cssp.course_group_id_ like concat('%',#{param.search},'%')
  230. or su.id_ like concat('%',#{param.search},'%')
  231. or su.username_ like concat('%',#{param.search},'%')
  232. or su.phone_ like concat('%',#{param.search},'%')
  233. )
  234. </if>
  235. <if test="param.orderNo != null and param.orderNo != ''">
  236. and cssp.order_no_ like concat('%',#{param.orderNo},'%')
  237. </if>
  238. <if test="param.startTime != null">
  239. and #{param.startTime} &lt;= cssp.created_time_
  240. </if>
  241. <if test="param.endTime != null">
  242. and #{param.endTime} &gt;= cssp.created_time_
  243. </if>
  244. </where>
  245. order by cssp.id_ desc
  246. </select>
  247. <select id="selectAdminLivePlan" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupPlanVo">
  248. select
  249. cs.id_ as courseId,
  250. cs.class_num_ as classNum,
  251. cs.class_date_ as classDate,
  252. cs.start_time_ as startTime,
  253. cs.end_time_ as endTime,
  254. cs.status_ as courseStatus,
  255. cp.plan_ as planInfo,
  256. lrv.url_ as videoUrl
  257. from course_schedule cs
  258. left join live_room_video lrv on cs.id_ = lrv.course_id_
  259. left join course_plan cp on cp.course_group_id_ = cs.course_group_id_ and cp.class_num_ = cs.class_num_
  260. <where>
  261. <if test="courseGroupId != null">
  262. and #{courseGroupId} = cs.course_group_id_
  263. </if>
  264. </where>
  265. order by cs.class_num_
  266. </select>
  267. <select id="selectAdminLiveCourseGroup" resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupVo">
  268. select distinct
  269. cg.id_ as courseGroupId,
  270. cg.name_ as name,
  271. cg.complete_course_num_ as endCourseNum,
  272. if(cg.complete_course_num_ = 0 ,cg.course_num_,cg.course_num_ - cg.complete_course_num_) as noStartCourseNum,
  273. cg.course_price_ as coursePrice,
  274. cg.pre_student_num_ as preStudentNum,
  275. cg.status_ as status,
  276. cg.course_num_ as courseNum,
  277. cg.created_time_ as createTime,
  278. cg.course_introduce_ as courseIntroduce,
  279. s.name_ as subjectName
  280. from course_group cg
  281. left join course_schedule_student_payment cssp on cg.id_ = cssp.course_group_id_
  282. left join subject s on cg.subject_id_ = s.id_
  283. <where>
  284. <if test="courseGroupId != null">
  285. and #{courseGroupId} = cg.id_
  286. </if>
  287. </where>
  288. </select>
  289. <select id="selectAdminLiveStudentCoursePage"
  290. resultType="com.yonge.cooleshow.biz.dal.vo.LiveCourseGroupStudentCourseVo">
  291. select distinct
  292. cs.id_ as courseId,
  293. cs.class_date_ as classDate,
  294. cs.start_time_ as startTime,
  295. cs.end_time_ as endTime,
  296. cs.status_ as courseStatue,
  297. cssp.order_no_ as orderNo,
  298. sa.id_ as studentAttendanceId
  299. from course_schedule cs
  300. left join course_schedule_student_payment cssp on cs.id_ = cssp.course_id_
  301. left join student_attendance sa on cssp.course_id_ = sa.course_schedule_id_
  302. <where>
  303. cs.status_ != '${@ com.yonge.cooleshow.biz.dal.enums.CourseScheduleEnum@CANCEL}'
  304. <if test="param.studentId != null">
  305. and cssp.user_id_ = #{param.studentId}
  306. </if>
  307. <if test="param.status != null">
  308. <choose>
  309. <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@TRUANT">
  310. and sa.id_ is null
  311. </when>
  312. <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@ATTENDCLASS">
  313. and sa.id_ is not null
  314. and #{param.studentId} = sa.student_id_
  315. </when>
  316. <when test="param.status == @com.yonge.cooleshow.biz.dal.enums.StudentCourseEnum@NOTSTART">
  317. and cs.status_ = '${@ com.yonge.cooleshow.biz.dal.enums.CourseScheduleEnum@NOT_START}'
  318. </when>
  319. </choose>
  320. </if>
  321. <if test="param.courseGroupId != null">
  322. and #{param.courseGroupId} = cs.course_group_id_
  323. </if>
  324. <if test="param.courseId != null">
  325. and cs.id_ like concat('%',#{param.courseId},'%')
  326. </if>
  327. </where>
  328. order by cs.id_ desc
  329. </select>
  330. <select id="selectPracticeGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPracticeVo">
  331. SELECT
  332. cg.id_ AS groupId,
  333. cg.name_ AS groupName,
  334. cg.subject_id_ AS subjectId,
  335. sub.name_ AS subjectName,
  336. cg.course_num_ AS courseNum,
  337. IFNULL(cs.count_ ,0)AS completeCount,
  338. cg.teacher_id_ AS teacherId,
  339. tu.username_ AS teacherName,
  340. tu.real_name_ AS teacherRealName,
  341. sp.user_id_ AS studentId,
  342. su.username_ AS studentName,
  343. su.real_name_ AS studentRealName,
  344. cg.status_ AS `status`,
  345. cst.start_time_ AS startTime
  346. FROM course_group cg
  347. LEFT JOIN `subject` sub ON cg.subject_id_=sub.id_
  348. LEFT JOIN sys_user tu ON cg.teacher_id_=tu.id_
  349. LEFT JOIN (SELECT user_id_,course_group_id_ FROM course_schedule_student_payment WHERE course_type_='PRACTICE' GROUP BY course_group_id_) sp ON cg.id_=sp.course_group_id_
  350. LEFT JOIN sys_user su ON sp.user_id_=su.id_
  351. LEFT JOIN (SELECT course_group_id_,COUNT(1) AS count_ FROM course_schedule WHERE type_='PRACTICE' AND status_='COMPLETE' GROUP BY course_group_id_) cs ON cg.id_=cs.course_group_id_
  352. LEFT JOIN (SELECT course_group_id_,start_time_ FROM course_schedule WHERE type_='PRACTICE' GROUP BY course_group_id_) cst ON cg.id_=cst.course_group_id_
  353. WHERE cg.type_='PRACTICE' AND cg.status_ IN('ING','COMPLETE')
  354. <if test="param.search != null and param.search != ''">
  355. AND (
  356. cg.id_ LIKE concat('%',#{param.search},'%') OR
  357. cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  358. sp.user_id_ LIKE concat('%',#{param.search},'%') OR
  359. cg.name_ LIKE concat('%',#{param.search},'%') OR
  360. tu.username_ LIKE concat('%',#{param.search},'%') OR
  361. su.username_ LIKE concat('%',#{param.search},'%')
  362. )
  363. </if>
  364. <if test="param.subjectId != null">
  365. AND cg.subject_id_ = #{param.subjectId}
  366. </if>
  367. <if test="param.status != null and param.status != ''">
  368. AND cg.status_ = #{param.status}
  369. </if>
  370. <if test="param.studentId != null">
  371. AND sp.user_id_ = #{param.studentId}
  372. </if>
  373. <if test="param.teacherId != null">
  374. AND cg.teacher_id_ = #{param.teacherId}
  375. </if>
  376. </select>
  377. <select id="selectPracticeGroupDetail"
  378. resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPracticeDetailVo">
  379. SELECT * FROM
  380. (SELECT
  381. cs.id_ AS courseId,
  382. sb.name_ AS subjectName,
  383. cs.teacher_id_ AS teacherId,
  384. tu.username_ AS teacherName,
  385. tu.real_name_ AS teacherRealName,
  386. sp.user_id_ AS studentId,
  387. su.username_ AS studentName,
  388. su.real_name_ AS studentRealName,
  389. cs.status_ AS `status`,
  390. cs.start_time_ AS startTime,
  391. cs.end_time_ AS endTime,
  392. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
  393. (CASE WHEN cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign,
  394. (CASE WHEN cs.start_time_ &gt;= sa.sign_in_time_ THEN 1 ELSE 0 END) AS studentInSign,
  395. (CASE WHEN cs.end_time_ &lt;= sa.sign_out_time_ THEN 1 ELSE 0 END) AS studentOutSign,
  396. ts.status_ AS salaryStatus
  397. FROM course_schedule cs
  398. LEFT JOIN course_group cg ON cs.course_group_id_=cg.id_
  399. LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
  400. LEFT JOIN sys_user tu ON cs.teacher_id_=tu.id_
  401. LEFT JOIN course_schedule_student_payment sp ON cs.id_=sp.course_id_
  402. LEFT JOIN sys_user su ON sp.user_id_=su.id_
  403. LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
  404. LEFT JOIN student_attendance sa ON cs.id_=sa.course_schedule_id_
  405. LEFT JOIN course_schedule_teacher_salary ts ON cs.id_=ts.course_schedule_id_
  406. WHERE cs.type_='PRACTICE'
  407. AND cs.lock_=0
  408. AND cs.course_group_id_=#{param.courseGroupId}) a
  409. <where>
  410. <if test="param.search != null and param.search != ''">
  411. AND (
  412. courseId LIKE concat('%',#{param.search},'%') OR
  413. teacherName LIKE concat('%',#{param.search},'%') OR
  414. teacherId LIKE concat('%',#{param.search},'%') OR
  415. studentName LIKE concat('%',#{param.search},'%') OR
  416. studentId LIKE concat('%',#{param.search},'%')
  417. )
  418. </if>
  419. <if test="param.teacherSign == 1">
  420. AND teacherInSign = #{param.teacherSign}
  421. </if>
  422. <if test="param.teacherSign == 0">
  423. AND teacherOutSign = #{param.teacherSign}
  424. </if>
  425. <if test="param.studentSign == 1">
  426. AND studentInSign = #{param.studentSign}
  427. </if>
  428. <if test="param.studentSign == 0">
  429. AND studentOutSign = #{param.studentSign}
  430. </if>
  431. <if test="param.status != null and param.status != ''">
  432. AND `status` = #{param.status}
  433. </if>
  434. <if test="param.salaryStatus != null and param.salaryStatus != ''">
  435. AND salaryStatus = #{param.salaryStatus}
  436. </if>
  437. <if test="param.startTime != null">
  438. AND startTime &lt;= #{param.startTime}
  439. </if>
  440. <if test="param.endTime != null">
  441. AND endTime &gt;= #{param.endTime}
  442. </if>
  443. <if test="param.studentId != null">
  444. AND studentId = #{param.studentId}
  445. </if>
  446. <if test="param.teacherId != null">
  447. AND teacherId = #{param.teacherId}
  448. </if>
  449. </where>
  450. </select>
  451. <select id="selectLiveGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupLiveVo">
  452. SELECT
  453. cg.id_ AS courseGroupId,
  454. cg.name_ AS courseGroupName,
  455. cg.subject_id_ AS subjectId,
  456. sb.name_ AS subjectName,
  457. cg.teacher_id_ AS teacherId,
  458. su.username_ AS teacherName,
  459. su.real_name_ AS teacherRealName,
  460. cg.course_num_ AS courseNum,
  461. cg.pre_student_num_ AS studentNum,
  462. cg.status_ AS `status`,
  463. IFNULL(cm.count_,0) AS completeCount,
  464. st.start_time_ AS startTime
  465. FROM course_group cg
  466. LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
  467. LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
  468. LEFT JOIN (SELECT course_group_id_,COUNT(1) AS count_ FROM course_schedule WHERE type_='LIVE' AND status_='COMPLETE' GROUP BY course_group_id_) cm ON cg.id_=cm.course_group_id_
  469. LEFT JOIN (SELECT course_group_id_,start_time_ FROM course_schedule WHERE type_='LIVE' GROUP BY course_group_id_) st ON cg.id_=st.course_group_id_
  470. WHERE cg.type_='LIVE'
  471. <if test="param.search != null and param.search != ''">
  472. AND (
  473. cg.id_ LIKE concat('%',#{param.search},'%') OR
  474. cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  475. cg.name_ LIKE concat('%',#{param.search},'%') OR
  476. su.username_ LIKE concat('%',#{param.search},'%')
  477. )
  478. </if>
  479. <if test="param.subjectId != null">
  480. AND cg.subject_id_ = #{param.subjectId}
  481. </if>
  482. <if test="param.status != null and param.status != ''">
  483. AND cg.status_ = #{param.status}
  484. </if>
  485. </select>
  486. <select id="selectLiveGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseSchedulePaymentVo">
  487. SELECT
  488. p.user_id_ AS studentId,
  489. u.username_ AS studentName,
  490. u.real_name_ AS studentRealName,
  491. u.phone_ AS studentPhone,
  492. p.actual_price_ AS actualPrice,
  493. p.order_no_ AS orderNo,
  494. o.create_time_ AS createdOrderTime
  495. FROM course_schedule_student_payment p
  496. LEFT JOIN sys_user u ON p.user_id_=u.id_
  497. LEFT JOIN user_order o ON p.order_no_ = o.order_no_
  498. WHERE p.course_group_id_=#{param.groupId}
  499. <if test="param.search != null and param.search != ''">
  500. AND (
  501. p.course_id_ LIKE concat('%',#{param.search},'%') OR
  502. p.user_id_ LIKE concat('%',#{param.search},'%') OR
  503. u.username_ LIKE concat('%',#{param.search},'%') OR
  504. u.phone_ LIKE concat('%',#{param.search},'%')
  505. )
  506. </if>
  507. <if test="param.orderNo != null and param.orderNo != ''">
  508. AND p.order_no_ = #{param.orderNo}
  509. </if>
  510. <if test="param.startTime != null">
  511. AND o.create_time_ &lt;= #{param.startTime}
  512. </if>
  513. <if test="param.endTime != null">
  514. AND o.create_time_ &gt;= #{param.endTime}
  515. </if>
  516. </select>
  517. <select id="selectLiveGroupPlan" resultType="com.yonge.cooleshow.biz.dal.vo.CourseSchedulePlanVo">
  518. SELECT
  519. cs.id_ AS courseId,
  520. g.course_introduce_ AS courseIntroduce,
  521. cs.class_num_ AS classNum,
  522. cs.class_date_ AS classDate,
  523. cs.start_time_ AS startTime,
  524. cs.end_time_ AS endTime,
  525. ts.status_ AS salaryStatus,
  526. v.url_ AS url,
  527. cs.status_ AS courseStatus,
  528. (CASE WHEN cs.start_time_ &gt;= ta.sign_in_time_ THEN 1 ELSE 0 END) AS teacherInSign,
  529. (CASE WHEN cs.end_time_ &lt;= ta.sign_out_time_ THEN 1 ELSE 0 END) AS teacherOutSign
  530. FROM course_schedule cs
  531. LEFT JOIN course_group g ON cs.course_group_id_=g.id_
  532. LEFT JOIN course_schedule_teacher_salary ts ON cs.id_=ts.course_schedule_id_
  533. LEFT JOIN live_room_video v ON cs.id_=v.course_id_
  534. LEFT JOIN teacher_attendance ta ON cs.id_=ta.course_schedule_id_
  535. WHERE cs.course_group_id_= #{param.groupId}
  536. <if test="param.salaryStatus != null and param.salaryStatus != ''">
  537. AND ts.status_ = #{param.salaryStatus}
  538. </if>
  539. <if test="param.startTime != null">
  540. AND cs.start_time_ &lt;= #{param.startTime}
  541. </if>
  542. <if test="param.endTime != null">
  543. AND cs.end_time_ &gt;= #{param.endTime}
  544. </if>
  545. <if test="param.endTime != null">
  546. AND cs.id_ LIKE concat('%',#{param.courseId},'%')
  547. </if>
  548. </select>
  549. <select id="selectVideoGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupVideoVo">
  550. SELECT
  551. g.id_ AS groupId,
  552. g.lesson_name_ AS lessonName,
  553. g.lesson_subject_ AS subjectId,
  554. s.name_ AS subjectName,
  555. g.lesson_count_ AS lessonCount,
  556. IFNULL(p.count_,0) AS buyCount,
  557. g.teacher_id_ AS teacherId,
  558. u.username_ AS teacherName,
  559. u.real_name_ AS teacherRealName,
  560. g.create_time_ AS createTime
  561. FROM video_lesson_group g
  562. LEFT JOIN `subject` s ON g.lesson_subject_=s.id_
  563. LEFT JOIN sys_user u ON g.teacher_id_=u.id_
  564. LEFT JOIN (
  565. SELECT video_lesson_group_id_,COUNT(1) AS count_ FROM video_lesson_purchase_record
  566. WHERE order_status_='PAID' GROUP BY video_lesson_group_id_) p ON g.id_=p.video_lesson_group_id_
  567. <where>
  568. <if test="param.search != null and param.search != ''">
  569. AND (
  570. g.id_ LIKE concat('%',#{param.search},'%') OR
  571. g.lesson_name_ LIKE concat('%',#{param.search},'%') OR
  572. g.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  573. u.username_ LIKE concat('%',#{param.search},'%')
  574. )
  575. </if>
  576. <if test="param.subjectId != null and param.subjectId != ''">
  577. AND g.lesson_subject_ = #{param.subjectId}
  578. </if>
  579. </where>
  580. </select>
  581. <select id="selectVideoGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupStudentVo">
  582. SELECT
  583. r.student_id_ AS studentId,
  584. u.username_ AS studentName,
  585. u.real_name_ AS studentRealName,
  586. u.phone_ AS studentPhone,
  587. r.order_no_ AS orderNo,
  588. r.pay_money_ AS payMoney,
  589. o.create_time_ AS createTime
  590. FROM video_lesson_purchase_record r
  591. LEFT JOIN sys_user u ON r.student_id_=u.id_
  592. LEFT JOIN user_order o ON r.order_no_=o.order_no_
  593. WHERE r.order_status_='PAID'
  594. AND video_lesson_group_id_ = #{param.groupId}
  595. <if test="param.search != null and param.search != ''">
  596. AND (
  597. r.student_id_ LIKE concat('%',#{param.search},'%') OR
  598. u.username_ LIKE concat('%',#{param.search},'%') OR
  599. u.phone_ LIKE concat('%',#{param.search},'%')
  600. )
  601. </if>
  602. <if test="param.orderNo != null and param.orderNo != ''">
  603. AND r.order_no_ = #{param.orderNo}
  604. </if>
  605. <if test="param.startTime != null">
  606. AND o.create_time_ &lt;= #{param.startTime}
  607. </if>
  608. <if test="param.endTime != null">
  609. AND o.create_time_ &gt;= #{param.endTime}
  610. </if>
  611. </select>
  612. <select id="selectVideoGroupPlan" resultType="com.yonge.cooleshow.biz.dal.entity.VideoLessonGroupDetail">
  613. SELECT
  614. id_ AS id,
  615. video_title_ AS videoTitle,
  616. video_content_ AS videoContent,
  617. video_url_ AS videoUrl,
  618. cover_url_ AS coverUrl
  619. FROM video_lesson_group_detail
  620. WHERE video_lesson_group_id_=#{param.groupId}
  621. </select>
  622. <select id="selectGroupInfoVo" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupInfoVo"
  623. parameterType="java.lang.Long">
  624. SELECT
  625. g.id_ AS id,
  626. g.name_ AS name,
  627. g.subject_id_ AS subjectId,
  628. s.name_ AS subjectName,
  629. g.course_num_ AS courseNum,
  630. g.course_price_ AS coursePrice,
  631. g.status_ AS `status`,
  632. g.course_introduce_ AS courseIntroduce,
  633. g.created_time_ AS createdTime
  634. FROM course_group g
  635. LEFT JOIN `subject` s ON g.subject_id_=s.id_
  636. WHERE g.id_ =#{groupId}
  637. </select>
  638. <update id="opsPreStudentNum">
  639. update course_group
  640. set
  641. pre_student_num_ = pre_student_num_ + #{num}
  642. where id_ = #{id}
  643. </update>
  644. <update id="updateBatch">
  645. UPDATE course_group
  646. SET status_='COMPLETE'
  647. WHERE id_ IN
  648. <foreach collection="list" item="item" open="(" separator="," close=")">
  649. #{item}
  650. </foreach>
  651. </update>
  652. <select id="selectPianoGroup" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
  653. SELECT
  654. cg.id_ AS courseGroupId,
  655. cg.name_ AS courseGroupName,
  656. cg.subject_id_ AS subjectId,
  657. sb.name_ AS subjectName,
  658. cg.teacher_id_ AS teacherId,
  659. su.username_ AS teacherName,
  660. su.real_name_ AS teacherRealName,
  661. cg.course_num_ AS courseNum,
  662. cg.status_ AS `status`,
  663. IFNULL(cm.count_,0) AS completeCount,
  664. st.start_time_ AS startTime
  665. FROM course_group cg
  666. LEFT JOIN `subject` sb ON cg.subject_id_=sb.id_
  667. LEFT JOIN sys_user su ON su.id_=cg.teacher_id_
  668. 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_
  669. 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_
  670. WHERE cg.type_='PIANO_ROOM_CLASS'
  671. <if test="param.search != null and param.search != ''">
  672. AND (
  673. cg.id_ LIKE concat('%',#{param.search},'%') OR
  674. cg.teacher_id_ LIKE concat('%',#{param.search},'%') OR
  675. cg.name_ LIKE concat('%',#{param.search},'%') OR
  676. su.username_ LIKE concat('%',#{param.search},'%')
  677. )
  678. </if>
  679. <if test="param.subjectId != null">
  680. AND cg.subject_id_ = #{param.subjectId}
  681. </if>
  682. <if test="param.status != null and param.status != ''">
  683. AND cg.status_ = #{param.status}
  684. </if>
  685. </select>
  686. <select id="selectPianoGroupDetail"
  687. resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoDetailVo">
  688. SELECT
  689. cs.id_ AS courseId,
  690. sb.id_ AS subjectId,
  691. sb.name_ AS subjectName,
  692. cs.teacher_id_ AS teacherId,
  693. tu.username_ AS teacherName,
  694. tu.real_name_ AS teacherRealName,
  695. cs.status_ AS `status`,
  696. a.studentCount AS studentCount,
  697. (cs.single_course_time_ * a.studentCount) AS course_time_,
  698. cs.start_time_ AS startTime,
  699. cs.end_time_ AS endTime,
  700. b.teacherInSign AS teacherInSign,
  701. b.teacherOutSign AS teacherOutSign
  702. FROM course_schedule cs
  703. LEFT JOIN course_group cg ON cs.course_group_id_ = cg.id_
  704. LEFT JOIN `subject` sb ON cg.subject_id_ = sb.id_
  705. LEFT JOIN sys_user tu ON cs.teacher_id_ = tu.id_
  706. 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_
  707. 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
  708. 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
  709. WHERE cs.type_='PIANO_ROOM_CLASS'
  710. AND cs.course_group_id_=#{param.courseGroupId}
  711. <if test="param.search != null and param.search != ''">
  712. AND cs.id_ LIKE concat('%',#{param.search},'%')
  713. </if>
  714. <if test="param.status != null and param.status != ''">
  715. AND cs.status_ = #{param.status}
  716. </if>
  717. <if test="param.startTime != null">
  718. AND cs.start_time_ &lt;= #{param.startTime}
  719. </if>
  720. <if test="param.endTime != null">
  721. AND cs.start_time_ &gt;= #{param.endTime}
  722. </if>
  723. <if test="param.teacherSign == 1">
  724. AND b.teacherInSign = #{param.teacherSign}
  725. </if>
  726. <if test="param.teacherSign == 0">
  727. AND b.teacherOutSign = #{param.teacherSign}
  728. </if>
  729. <if test="param.studentSign != null">
  730. AND cs.id_ IN
  731. <foreach collection="param.courseIds" item="item" open="(" close=")" separator=",">
  732. #{item}
  733. </foreach>
  734. </if>
  735. </select>
  736. <select id="studentSign" resultType="com.yonge.cooleshow.biz.dal.vo.StudentSignVo">
  737. SELECT
  738. p.course_id_ AS courseId,
  739. p.user_id_ AS userId,
  740. u.username_ AS userName,
  741. u.real_name_ AS realName,
  742. ( CASE WHEN c.start_time_ &gt;= a.sign_in_time_ THEN 1 ELSE 0 END ) AS studentInSign,
  743. ( CASE WHEN c.end_time_ &lt;= a.sign_out_time_ THEN 1 ELSE 0 END ) AS studentOutSign
  744. FROM course_schedule_student_payment p
  745. LEFT JOIN sys_user u ON p.user_id_=u.id_
  746. LEFT JOIN course_schedule c ON p.course_id_=c.id_
  747. LEFT JOIN student_attendance a ON p.user_id_=a.student_id_
  748. <where>
  749. <if test="courseId !=null">
  750. AND p.course_id_=#{courseId}
  751. </if>
  752. <if test="type !=null and type!=''">
  753. AND p.course_type_=#{type}
  754. </if>
  755. </where>
  756. </select>
  757. <select id="selectPianoGroupStudent" resultType="com.yonge.cooleshow.biz.dal.vo.CourseGroupPianoVo">
  758. SELECT DISTINCT
  759. g.id_ AS courseGroupId,
  760. g.name_ AS courseGroupName,
  761. s.id_ AS subjectId,
  762. s.name_ AS subjectName,
  763. g.teacher_id_ AS teacherId,
  764. u.username_ AS teacherName,
  765. u.real_name_ AS teacherRealName,
  766. g.course_num_ AS courseNum,
  767. IFNULL(cm.count_,0) AS completeCount,
  768. g.status_ AS `status`,
  769. st.start_time_ AS startTime
  770. FROM course_schedule_student_payment p
  771. LEFT JOIN course_group g ON p.course_group_id_=g.id_
  772. LEFT JOIN `subject` s ON g.subject_id_=s.id_
  773. LEFT JOIN sys_user u ON g.teacher_id_=u.id_
  774. 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_
  775. 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_
  776. WHERE p.course_type_='PIANO_ROOM_CLASS'
  777. AND p.user_id_=#{param.studentId}
  778. <if test="param.search != null and param.search != ''">
  779. AND (
  780. g.id_ LIKE concat('%',#{param.search},'%') OR
  781. g.name_ LIKE concat('%',#{param.search},'%')
  782. )
  783. </if>
  784. <if test="param.subjectId != null">
  785. AND s.id_ = #{param.subjectId}
  786. </if>
  787. <if test="param.status != null and param.status != ''">
  788. AND g.status_ = #{param.status}
  789. </if>
  790. </select>
  791. </mapper>