ClassGroupTeacherMapperMapper.xml 9.4 KB

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