ClassGroupTeacherMapperMapper.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  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. <mapper namespace="com.ym.mec.biz.dal.dao.ClassGroupTeacherMapperDao">
  5. <resultMap type="com.ym.mec.biz.dal.entity.ClassGroupTeacherMapper"
  6. id="ClassGroupTeacherMapper">
  7. <result column="id_" property="id"/>
  8. <result column="group_type_" property="groupType" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  9. <result column="music_group_id_" property="musicGroupId"/>
  10. <result column="class_group_id_" property="classGroupId"/>
  11. <result column="teacher_role_" property="teacherRole"/>
  12. <result column="real_name_" property="realName"/>
  13. <result column="user_id_" property="userId"/>
  14. <result column="salary_" property="salary"/>
  15. <result column="create_time_" property="createTime"/>
  16. <result column="update_time_" property="updateTime"/>
  17. <result column="tenant_id_" property="tenantId" />
  18. </resultMap>
  19. <resultMap id="ClassGroupTeacherMapDto" type="com.ym.mec.biz.dal.dto.ClassGroupTeacherMapDto" extends="ClassGroupTeacherMapper">
  20. <result column="username_" property="userName"/>
  21. </resultMap>
  22. <!-- 根据主键查询一条记录 -->
  23. <select id="get" resultMap="ClassGroupTeacherMapper">
  24. SELECT *
  25. FROM class_group_teacher_mapper WHERE id_ = #{id}
  26. </select>
  27. <!-- 全查询 -->
  28. <select id="findAll" resultMap="ClassGroupTeacherMapper">
  29. SELECT *
  30. FROM class_group_teacher_mapper where tenant_id_ = #{tenantId}
  31. ORDER BY id_
  32. </select>
  33. <!-- 向数据库增加一条记录 -->
  34. <insert id="insert" parameterType="com.ym.mec.biz.dal.entity.ClassGroupTeacherMapper"
  35. useGeneratedKeys="true" keyColumn="id" keyProperty="id">
  36. INSERT INTO class_group_teacher_mapper
  37. (group_type_,music_group_id_,class_group_id_,teacher_role_,user_id_,salary_,create_time_,update_time_,tenant_id_)
  38. VALUES(#{groupType,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},#{musicGroupId},
  39. #{classGroupId},#{teacherRole},#{userId},#{salary},NOW(),NOW(),#{tenantId})
  40. </insert>
  41. <!-- 根据主键查询一条记录 -->
  42. <update id="update" parameterType="com.ym.mec.biz.dal.entity.ClassGroupTeacherMapper">
  43. UPDATE class_group_teacher_mapper
  44. <set>
  45. <if test="userId != null">
  46. user_id_ = #{userId},
  47. </if>
  48. <if test="groupType != null">
  49. group_type_ = #{groupType,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  50. </if>
  51. <if test="classGroupId != null">
  52. class_group_id_ = #{classGroupId},
  53. </if>
  54. <if test="salary != null">
  55. salary_ = #{salary},
  56. </if>
  57. <if test="updateTime != null">
  58. update_time_ = NOW(),
  59. </if>
  60. <if test="teacherRole != null">
  61. teacher_role_ = #{teacherRole},
  62. </if>
  63. <if test="musicGroupId != null">
  64. music_group_id_ = #{musicGroupId},
  65. </if>
  66. </set>
  67. WHERE id_ = #{id} and tenant_id_ = #{tenantId}
  68. </update>
  69. <update id="updateTeacher">
  70. UPDATE class_group_teacher_mapper SET user_id_ = #{teacherId},update_time_ = NOW()
  71. WHERE teacher_role_ = 'BISHOP' AND music_group_id_ = #{groupId} AND group_type_ = #{groupType}
  72. </update>
  73. <update id="batchUpdateTeacherByClassId">
  74. UPDATE class_group_teacher_mapper SET user_id_ = #{newTeacherId},update_time_ = NOW() WHERE user_id_ = #{oldTeacherId} AND class_group_id_ IN
  75. <foreach collection="classGroupIds" item="item" open="(" close=")" separator=",">
  76. #{item}
  77. </foreach>
  78. </update>
  79. <!-- 根据主键删除一条记录 -->
  80. <delete id="delete">
  81. DELETE FROM class_group_teacher_mapper WHERE
  82. id_ = #{id}
  83. </delete>
  84. <!-- 分页查询 -->
  85. <select id="queryPage" resultMap="ClassGroupTeacherMapper"
  86. parameterType="map">
  87. SELECT * FROM class_group_teacher_mapper where tenant_id_ = #{tenantId} ORDER BY id_
  88. <include refid="global.limit"/>
  89. </select>
  90. <!-- 查询当前表的总记录数 -->
  91. <select id="queryCount" resultType="int">
  92. SELECT COUNT(*)
  93. FROM class_group_teacher_mapper where tenant_id_ = #{tenantId}
  94. </select>
  95. <!-- 批量插入班级老师 -->
  96. <insert id="classGroupTeachersInsert" parameterType="java.util.List">
  97. INSERT INTO class_group_teacher_mapper
  98. (id_,group_type_,music_group_id_,class_group_id_,teacher_role_,user_id_,salary_,create_time_,update_time_,tenant_id_)
  99. VALUE
  100. <foreach collection="classGroupTeacherMapperList" item="item" index="index" separator=",">
  101. (#{item.id},#{item.groupType,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},#{item.musicGroupId},#{item.classGroupId},#{item.teacherRole},#{item.userId},#{item.salary},NOW(),NOW(),#{item.tenantId})
  102. </foreach>
  103. </insert>
  104. <!-- 获取乐团班级的老师 -->
  105. <select id="findClassGroupTeachers" resultMap="ClassGroupTeacherMapper">
  106. SELECT u.real_name_, ct.*
  107. FROM sys_user u,
  108. class_group_teacher_mapper ct
  109. WHERE u.id_=ct.user_id_ AND FIND_IN_SET(ct.class_group_id_,#{classGroupIds})
  110. </select>
  111. <select id="findByClassGroupAndRole" resultMap="ClassGroupTeacherMapper">
  112. SELECT u.real_name_, ct.*
  113. FROM sys_user u,
  114. class_group_teacher_mapper ct
  115. WHERE ct.class_group_id_ = #{classGroupId}
  116. AND ct.user_id_=u.id_
  117. AND teacher_role_=#{teacherRole,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}
  118. </select>
  119. <select id="findByMusicGroup" resultMap="ClassGroupTeacherMapper">
  120. SELECT u.real_name_, ct.*
  121. FROM sys_user u,
  122. class_group_teacher_mapper ct
  123. WHERE ct.music_group_id_ = #{musicGroupId}
  124. AND ct.user_id_=u.id_
  125. AND ct.teacher_role_ = 'BISHOP'
  126. </select>
  127. <select id="findAllByMusicGroup" resultMap="ClassGroupTeacherMapper">
  128. SELECT u.real_name_, ct.*
  129. FROM sys_user u,
  130. class_group_teacher_mapper ct
  131. <where>
  132. ct.user_id_ = u.id_
  133. <if test="groupType!=null">
  134. AND ct.group_type_=#{groupType,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}
  135. </if>
  136. <if test="teacherRole != null">
  137. AND ct.teacher_role_ = #{teacherRole}
  138. </if>
  139. <if test="musicGroupId != null">
  140. AND ct.music_group_id_=#{musicGroupId}
  141. </if>
  142. <if test="tenantId != null">
  143. AND ct.tenant_id_=#{tenantId}
  144. </if>
  145. </where>
  146. </select>
  147. <!-- 删除对应班级老师关联关系 -->
  148. <delete id="delMusicGroupTeacherMapper">
  149. DELETE FROM class_group_teacher_mapper WHERE class_group_id_ IN
  150. <foreach collection="classGroupTeacherMapperList" item="item" index="index" open="(" close=")" separator=",">
  151. #{item.classGroupId}
  152. </foreach>
  153. </delete>
  154. <!-- 获取班级老师关联关系 -->
  155. <select id="getClassGroupTeacherMapper" resultMap="ClassGroupTeacherMapper">
  156. SELECT * FROM class_group_teacher_mapper WHERE class_group_id_ IN
  157. <foreach collection="classGroupTeacherMapperList" item="item" index="index" open="(" close=")" separator=",">
  158. #{item.classGroupId}
  159. </foreach>
  160. AND group_type_ = #{groupType,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}
  161. </select>
  162. <select id="queryTeachingNames" resultType="java.lang.String">
  163. SELECT GROUP_CONCAT(su.real_name_) FROM class_group_teacher_mapper cgtm
  164. LEFT JOIN sys_user su ON cgtm.user_id_ = su.id_
  165. WHERE cgtm.teacher_role_ = 'TEACHING' AND cgtm.class_group_id_ = #{classGroupId}
  166. </select>
  167. <select id="findByClassGroup" resultMap="ClassGroupTeacherMapper">
  168. SELECT * FROM class_group_teacher_mapper WHERE class_group_id_=#{classGroupId}
  169. </select>
  170. <select id="findByClassGroupAndTeacher" resultMap="ClassGroupTeacherMapper">
  171. SELECT * FROM class_group_teacher_mapper WHERE class_group_id_=#{classGroupId} AND user_id_=#{userId}
  172. </select>
  173. <select id="findByClassGroupIds" resultMap="ClassGroupTeacherMapDto">
  174. SELECT
  175. cgtm.*,
  176. su.real_name_ username_
  177. FROM
  178. class_group_teacher_mapper cgtm
  179. LEFT JOIN sys_user su ON cgtm.user_id_ = su.id_
  180. WHERE cgtm.class_group_id_ IN
  181. <foreach collection="classGroupIds" item="classGroupId" open="(" close=")" separator=",">
  182. #{classGroupId}
  183. </foreach>
  184. </select>
  185. <!-- 删除对应班级老师关联关系 -->
  186. <delete id="delClassGroupTeacherMapper">
  187. DELETE FROM class_group_teacher_mapper WHERE class_group_id_ IN
  188. <foreach collection="classGroupIds" item="classGroupId" index="index" open="(" close=")" separator=",">
  189. #{classGroupId}
  190. </foreach>
  191. </delete>
  192. <delete id="deleteByGroup">
  193. DELETE FROM class_group_teacher_mapper WHERE music_group_id_=#{groupId} AND group_type_=#{groupType,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}
  194. </delete>
  195. <select id="findByClassGroupIdsAndType" resultMap="ClassGroupTeacherMapper">
  196. SELECT * FROM class_group_teacher_mapper WHERE class_group_id_ IN
  197. <foreach collection="classGroupIds" item="classGroupId" open="(" close=")" separator=",">
  198. #{classGroupId}
  199. </foreach>
  200. <if test="teacherRole != null ">
  201. AND teacher_role_ = #{teacherRole}
  202. </if>
  203. </select>
  204. <select id="getClassGroupTeachersRole" resultMap="ClassGroupTeacherMapper">
  205. SELECT u.real_name_, ct.*
  206. FROM sys_user u,
  207. class_group_teacher_mapper ct
  208. WHERE u.id_ = ct.user_id_ AND ct.class_group_id_ = #{classGroupId} AND ct.teacher_role_ = #{teacherRole} LIMIT 1
  209. </select>
  210. <select id="queryTeacherIdsByClassGroupId" resultType="java.lang.Integer">
  211. SELECT DISTINCT user_id_ FROM class_group_teacher_mapper
  212. <include refid="queryTeacherIdsByClassGroupIdSql"/>
  213. UNION ALL
  214. SELECT DISTINCT user_id_ FROM course_schedule_teacher_salary
  215. <include refid="queryTeacherIdsByClassGroupIdSql"/>
  216. </select>
  217. <sql id="queryTeacherIdsByClassGroupIdSql">
  218. <where>
  219. class_group_id_ = #{classGroupId}
  220. <if test="groupType != null">
  221. AND group_type_ = #{groupType,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}
  222. </if>
  223. <if test="musicGroupId != null">
  224. AND music_group_id_ = #{musicGroupId}
  225. </if>
  226. </where>
  227. </sql>
  228. </mapper>