DemoGroupMapper.xml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  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. <!--
  4. 这个文件是自动生成的。
  5. 不要修改此文件。所有改动将在下次重新自动生成时丢失。
  6. -->
  7. <mapper namespace="com.ym.mec.biz.dal.dao.DemoGroupDao">
  8. <resultMap type="com.ym.mec.biz.dal.entity.DemoGroup" id="DemoGroup">
  9. <result column="id_" property="id"/>
  10. <result column="name_" property="name"/>
  11. <result column="single_class_minutes_" property="singleClassMinutes"/>
  12. <result column="organ_id_list_" property="organIdList"/>
  13. <result column="create_time_" property="createTime"/>
  14. <result column="update_time_" property="updateTime"/>
  15. <result column="user_id_" property="userId"/>
  16. <result column="price_" property="price"/>
  17. <result column="subject_id_" property="subjectId"/>
  18. <result column="subject_name_" property="subjectName"/>
  19. </resultMap>
  20. <resultMap id="studentDemoGroupListDto" type="com.ym.mec.biz.dal.dto.StudentDemoGroupListDto">
  21. <result property="demoGroupId" column="demo_group_id_"/>
  22. <result property="userId" column="user_id_"/>
  23. <result property="userName" column="username_"/>
  24. <result property="avatar" column="avatar_"/>
  25. <result property="introduction" column="introduction_"/>
  26. <result property="numberOfClasses" column="number_of_classes_"/>
  27. <result property="subjectName" column="subject_name_"/>
  28. <collection property="coursesPlans"
  29. resultMap="com.ym.mec.biz.dal.dao.DemoGroupCoursesPlanDao.DemoGroupCoursesPlan" column="dgcp.id_"/>
  30. </resultMap>
  31. <!-- 根据主键查询一条记录 -->
  32. <select id="get" resultMap="DemoGroup">
  33. SELECT * FROM demo_group WHERE id_ = #{id}
  34. </select>
  35. <!-- 全查询 -->
  36. <select id="findAll" resultMap="DemoGroup">
  37. SELECT * FROM demo_group ORDER BY id_
  38. </select>
  39. <select id="findById" resultMap="DemoGroup">
  40. SELECT
  41. dg.id_,
  42. dg.name_,
  43. dg.single_class_minutes_,
  44. dg.organ_id_list_,
  45. dg.create_time_,
  46. dg.update_time_,
  47. dg.user_id_,
  48. dg.price_,
  49. dg.subject_id_,
  50. s.name_ subject_name_
  51. FROM
  52. demo_group dg
  53. LEFT JOIN `subject` s ON dg.subject_id_=s.id_
  54. WHERE dg.id_ = #{id}
  55. </select>
  56. <!-- 向数据库增加一条记录 -->
  57. <insert id="insert" parameterType="com.ym.mec.biz.dal.entity.DemoGroup" useGeneratedKeys="true" keyColumn="id"
  58. keyProperty="id">
  59. <!--
  60. <selectKey resultClass="int" keyProperty="id" >
  61. SELECT SEQ_WSDEFINITION_ID.nextval AS ID FROM DUAL
  62. </selectKey>
  63. -->
  64. INSERT INTO demo_group
  65. (name_,single_class_minutes_,organ_id_list_,create_time_,update_time_,user_id_,price_,subject_id_)
  66. VALUES(#{name},#{singleClassMinutes},#{organIdList},now(),now(),#{userId},#{price},#{subjectId})
  67. </insert>
  68. <!-- 根据主键查询一条记录 -->
  69. <update id="update" parameterType="com.ym.mec.biz.dal.entity.DemoGroup">
  70. UPDATE demo_group
  71. <set>
  72. <if test="userId != null">
  73. user_id_ = #{userId},
  74. </if>
  75. <if test="updateTime != null">
  76. update_time_ = NOW(),
  77. </if>
  78. <if test="singleClassMinutes != null">
  79. single_class_minutes_ = #{singleClassMinutes},
  80. </if>
  81. <if test="organIdList != null">
  82. organ_id_list_ = #{organIdList},
  83. </if>
  84. <if test="name != null">
  85. name_ = #{name},
  86. </if>
  87. <if test="price != null">
  88. price_ = #{price},
  89. </if>
  90. <if test="subjectId != null">
  91. subject_id_ = #{subjectId},
  92. </if>
  93. </set>
  94. WHERE id_ = #{id}
  95. </update>
  96. <!-- 根据主键删除一条记录 -->
  97. <delete id="delete">
  98. DELETE FROM demo_group WHERE id_ = #{id}
  99. </delete>
  100. <!-- 分页查询 -->
  101. <select id="queryPage" resultMap="DemoGroup" parameterType="map">
  102. SELECT * FROM demo_group ORDER BY id_
  103. <include refid="global.limit"/>
  104. </select>
  105. <!-- 查询当前表的总记录数 -->
  106. <select id="queryCount" resultType="int">
  107. SELECT COUNT(*) FROM demo_group
  108. </select>
  109. <select id="organIdListByDemoGroupId" resultType="int">
  110. SELECT
  111. su.organ_id_
  112. FROM
  113. class_group_student_mapper cgsm
  114. LEFT JOIN sys_user su ON cgsm.user_id_=su.id_
  115. WHERE cgsm.music_group_id_=#{demoGroupId} AND cgsm.group_type_='DEMO' AND cgsm.status_ != 'QUIT'
  116. </select>
  117. <select id="getOrganIdByUserId" resultType="java.lang.Integer">
  118. select organ_id_ from sys_user where id_=#{userId}
  119. </select>
  120. <select id="createCourseSchedulesByDemoGroup" parameterType="com.ym.mec.biz.dal.entity.DemoGroup"
  121. resultMap="com.ym.mec.biz.dal.dao.CourseScheduleDao.CourseSchedule">
  122. SELECT
  123. #{classGroupId} class_group_id_,
  124. 'NOT_START' status_,
  125. DATE_FORMAT(dgcp.courses_start_time_,'%Y-%m-%d') class_date_,
  126. dgcp.courses_start_time_ start_class_time_,
  127. DATE_ADD(dgcp.courses_start_time_,INTERVAL #{demoGroup.singleClassMinutes} MINUTE) end_class_time_,
  128. #{demoGroup.userId} teacher_id_,
  129. 'ONLINE' teach_mode_,
  130. 'demo' type_
  131. FROM
  132. demo_group_courses_plan dgcp
  133. WHERE dgcp.demo_group_id_=#{demoGroup.id} AND dgcp.courses_start_time_ = #{startTime}
  134. </select>
  135. <select id="createCourseScheduleByDemoGroupPlan" parameterType="com.ym.mec.biz.dal.entity.DemoGroup"
  136. resultMap="com.ym.mec.biz.dal.dao.CourseScheduleDao.CourseSchedule">
  137. SELECT
  138. #{classGroupId} class_group_id_,
  139. 'NOT_START' status_,
  140. dgcp.course_date_ class_date_,
  141. CONCAT(dgcp.course_date_,' ',dgcp.start_time_) start_class_time_,
  142. DATE_ADD( CONCAT(dgcp.course_date_,' ',dgcp.start_time_),INTERVAL #{demoGroup.singleClassMinutes} MINUTE) end_class_time_,
  143. #{demoGroup.userId} teacher_id_,
  144. #{demoGroup.userId} actual_teacher_id_,
  145. 'ONLINE' teach_mode_,
  146. 'DEMO' type_
  147. FROM
  148. demo_group_courses_plan dgcp
  149. WHERE dgcp.id_=#{coursePlanId}
  150. </select>
  151. <select id="countDemoGroupStudents" resultType="java.lang.Integer">
  152. SELECT
  153. count(cgsm.user_id_)
  154. FROM
  155. class_group_student_mapper cgsm
  156. WHERE cgsm.music_group_id_=#{demoGroupId} AND cgsm.group_type_='DEMO' AND cgsm.status_ != 'QUIT'
  157. </select>
  158. <sql id="demoGroupQueryCondition">
  159. <where>
  160. dgcp.status_=0
  161. AND CONCAT(dgcp.course_date_,' ',dgcp.start_time_)&gt;=NOW()
  162. <if test="search!=null">
  163. AND su.username_ like concat('%',#{search},'%')
  164. </if>
  165. <if test="subjectIds!=null and subjectIds!=''">
  166. AND FIND_IN_SET(dg.subject_id_,#{subjectIds})
  167. </if>
  168. <if test="startTime!=null and endTime==null">
  169. AND CONCAT(dgcp.course_date_,' ',dgcp.start_time_)&gt;=DATE_FORMAT(#{startTime},'%Y-%m-%d %H:%i:%S')
  170. AND dgcp.course_date_=DATE_FORMAT(#{startTime},'%Y-%m-%d')
  171. </if>
  172. <if test="startTime!=null and endTime!=null">
  173. AND (CONCAT(dgcp.course_date_,' ',dgcp.start_time_) BETWEEN DATE_FORMAT(#{startTime},'%Y-%m-%d %H:%i:%S') AND DATE_FORMAT(#{endTime},'%Y-%m-%d %H:%i:%S'))
  174. </if>
  175. </where>
  176. </sql>
  177. <sql id="demoGroupQueryCondition1">
  178. <where>
  179. dgcp.status_=0
  180. AND dgcp.demo_group_id_ IN
  181. <foreach collection="demoGroupIds" item="demoGroupId" open="(" close=")" separator=",">
  182. #{demoGroupId}
  183. </foreach>
  184. AND CONCAT(dgcp.course_date_,' ',dgcp.start_time_)&gt;=NOW()
  185. <if test="params.search!=null">
  186. AND su.username_ like concat('%',#{params.search},'%')
  187. </if>
  188. <if test="params.subjectIds!=null and params.subjectIds!=''">
  189. AND FIND_IN_SET(dg.subject_id_,#{params.subjectIds})
  190. </if>
  191. <if test="params.startTime!=null and params.endTime==null">
  192. AND CONCAT(dgcp.course_date_,' ',dgcp.start_time_)&gt;=DATE_FORMAT(#{params.startTime},'%Y-%m-%d %H:%i:%S')
  193. AND dgcp.course_date_=DATE_FORMAT(#{params.startTime},'%Y-%m-%d')
  194. </if>
  195. <if test="params.startTime!=null and params.endTime!=null">
  196. AND (CONCAT(dgcp.course_date_,' ',dgcp.start_time_) BETWEEN DATE_FORMAT(#{params.startTime},'%Y-%m-%d %H:%i:%S') AND DATE_FORMAT(#{params.endTime},'%Y-%m-%d %H:%i:%S'))
  197. </if>
  198. </where>
  199. </sql>
  200. <select id="findDemoGroupList" resultMap="studentDemoGroupListDto">
  201. SELECT
  202. dg.id_ demo_group_id_,
  203. su.real_name_ username_,
  204. su.avatar_,
  205. t.introduction_,
  206. s.name_ subject_name_,
  207. COUNT(cg.id_) number_of_classes_,
  208. dgcp.id_,
  209. dgcp.demo_group_id_,
  210. dgcp.create_time_,
  211. dgcp.status_,
  212. dgcp.course_date_,
  213. CONCAT(dgcp.course_date_,' ',dgcp.start_time_) start_time_,
  214. CONCAT(dgcp.course_date_,' ',dgcp.end_time_) end_time_
  215. FROM
  216. demo_group dg
  217. LEFT JOIN demo_group_courses_plan dgcp ON dg.id_=dgcp.demo_group_id_
  218. LEFT JOIN teacher t ON dg.user_id_=t.id_
  219. LEFT JOIN sys_user su ON dg.user_id_=su.id_
  220. LEFT JOIN `subject` s ON dg.subject_id_=s.id_
  221. LEFT JOIN class_group cg ON dg.id_=cg.music_group_id_ AND cg.group_type_='DEMO'
  222. <include refid="demoGroupQueryCondition1"/>
  223. GROUP BY dgcp.id_,dg.id_
  224. ORDER BY dgcp.start_time_
  225. </select>
  226. <select id="countDemoGroupList" resultType="java.lang.Integer">
  227. SELECT
  228. COUNT(DISTINCT dg.id_)
  229. FROM
  230. demo_group dg
  231. LEFT JOIN demo_group_courses_plan dgcp ON dg.id_ = dgcp.demo_group_id_
  232. LEFT JOIN sys_user su ON dg.user_id_ = su.id_
  233. <include refid="demoGroupQueryCondition"/>
  234. </select>
  235. <select id="findDemoGoupIds" resultType="java.lang.Integer">
  236. SELECT
  237. DISTINCT dg.id_
  238. FROM
  239. demo_group dg
  240. LEFT JOIN demo_group_courses_plan dgcp ON dg.id_ = dgcp.demo_group_id_
  241. LEFT JOIN sys_user su ON dg.user_id_ = su.id_
  242. <include refid="demoGroupQueryCondition"/>
  243. <include refid="global.limit"/>
  244. </select>
  245. <select id="findClassGroupIDByDemoGroupId" resultType="java.lang.Integer">
  246. SELECT
  247. id_
  248. FROM
  249. class_group
  250. WHERE music_group_id_=#{demoGroupId} AND group_type_='DEMO'
  251. </select>
  252. <select id="findDemoGroupByTeacherId" resultMap="DemoGroup">
  253. SELECT * FROM demo_group WHERE user_id_=#{teacherId}
  254. </select>
  255. <select id="findTeacherDemoGroups" resultType="com.ym.mec.biz.dal.dto.TeacherManageDemoGroupListDto">
  256. SELECT
  257. cs.class_date_ classDate,
  258. GROUP_CONCAT(DISTINCT CONCAT(cs.start_class_time_,' ',cs.end_class_time_)) startTimes,
  259. GROUP_CONCAT(DISTINCT s.name_) subjectNames
  260. FROM
  261. demo_group dg
  262. LEFT JOIN class_group cg ON dg.id_=cg.music_group_id_ AND cg.group_type_='DEMO'
  263. LEFT JOIN course_schedule cs ON cg.id_=cs.class_group_id_
  264. LEFT JOIN `subject` s ON s.id_ = dg.subject_id_
  265. WHERE
  266. (cs.del_flag_ != 1 OR cs.del_flag_ IS NULL)
  267. AND cs.type_ = 'DEMO' AND dg.user_id_ = #{teacherId}
  268. GROUP BY cs.class_date_
  269. <include refid="global.limit"/>
  270. </select>
  271. <select id="countTeacherDemoGroups" resultType="Integer">
  272. SELECT COUNT(DISTINCT cs.class_date_) FROM course_schedule cs WHERE cs.type_ = 'DEMO' AND cs.actual_teacher_id_ = #{teacherId}
  273. </select>
  274. <select id="findDemoGroupStartClassTimesWithWeekByTeacherId"
  275. resultType="com.ym.mec.biz.dal.dto.EducationDemoGroupListDto">
  276. SELECT
  277. class_date_ classDate,
  278. GROUP_CONCAT(start_class_time_) startClassTimes
  279. FROM
  280. course_schedule
  281. WHERE
  282. YEARWEEK(class_date_) = YEARWEEK( now( ) )
  283. GROUP BY class_date_
  284. </select>
  285. <select id="countTeacherDemoGroupNum" resultType="java.util.Map">
  286. SELECT dg.user_id_ `key`,COUNT(dg.id_) `value` FROM demo_group dg
  287. WHERE FIND_IN_SET(dg.user_id_,#{teacherIds}) GROUP BY user_id_
  288. </select>
  289. <select id="queryDemoGroupNum" resultType="map">
  290. select sum(case when dgcp.status_ = 0 then 1 else 0 end) unbooked_num_,
  291. sum(case when dgcp.status_ = 1 then 1 else 0 end) booked_num_
  292. from demo_group_courses_plan dgcp left join demo_group dg on dgcp.demo_group_id_ = dg.id_
  293. <where>
  294. <if test="organIds != null">
  295. AND INTE_ARRAY(dg.organ_id_list_,#{organIds})
  296. </if>
  297. </where>
  298. </select>
  299. <select id="queryCurrentMonthCoursesNum" resultType="int">
  300. select count(cs.id_) from course_schedule cs
  301. left join demo_group vg on cs.music_group_id_ = vg.id_
  302. where cs.type_ = 'DEMO'
  303. and DATE_FORMAT(cs.class_date_, '%Y%m' ) = DATE_FORMAT(CURDATE() , '%Y%m') and (cs.del_flag_ = 0 or cs.del_flag_ is null)
  304. <if test="organIds != null">
  305. AND INTE_ARRAY(vg.organ_id_list_,#{organIds})
  306. </if>
  307. </select>
  308. </mapper>