DemoGroupMapper.xml 13 KB

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