StudentRegistrationMapper.xml 65 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559
  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.StudentRegistrationDao">
  8. <resultMap type="com.ym.mec.biz.dal.entity.StudentRegistration" id="StudentRegistration">
  9. <result column="id_" property="id"/>
  10. <result column="user_id_" property="userId"/>
  11. <result column="name_" property="name"/>
  12. <result column="id_card_no_" property="idCardNo"/>
  13. <result column="music_group_id_" property="musicGroupId"/>
  14. <result column="current_grade_" property="currentGrade"/>
  15. <result column="current_grade_date_" property="currentGradeDate"/>
  16. <result column="current_grade_" property="currentGrade"/>
  17. <result column="current_grade_num_" property="currentGradeNum"/>
  18. <result column="current_class_" property="currentClass"/>
  19. <result column="subject_id_" property="subjectId"/>
  20. <result column="actual_subject_id_" property="actualSubjectId"/>
  21. <result column="is_allow_adjust_" property="isAllowAdjust"
  22. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  23. <result column="kit_purchase_method_" property="kitPurchaseMethod"
  24. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  25. <result column="remark_" property="remark"/>
  26. <result column="class_group_id_" property="classGroupId"/>
  27. <result column="create_time_" property="createTime"/>
  28. <result column="update_time_" property="updateTime"/>
  29. <result column="parents_name_" property="parentsName"/>
  30. <result column="parents_phone_" property="parentsPhone"/>
  31. <result column="parents_company_" property="parentsCompany"/>
  32. <result column="payment_status_" property="paymentStatus"
  33. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  34. <result column="music_group_status_" property="musicGroupStatus"
  35. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  36. <result column="class_group_name_" property="classGroupName"/>
  37. <result column="temporary_course_fee_" property="temporaryCourseFee"/>
  38. <result column="birthdate_" property="birthdate"/>
  39. <result column="gender_" property="gender"/>
  40. <result column="organ_name_" property="organName"/>
  41. <result column="organ_id_" property="organId"/>
  42. <result column="school_name_" property="schoolName"/>
  43. <result column="subject_name_" property="subjectName"/>
  44. <result column="kit_group_purchase_type_" property="kitType"/>
  45. <result column="username_" property="name"/>
  46. <result column="deposit_fee_" property="depositFee"/>
  47. <result column="surplus_course_fee_" property="surplusCourseFee"/>
  48. <result column="paying_status_" property="payingStatus"/>
  49. <result column="has_cloud_teacher_" property="hasCloudTeacher"/>
  50. <result column="none_need_cloud_teacher_" property="noneNeedCloudTeacher"/>
  51. <result column="membership_end_time_" property="membershipEndTime"/>
  52. </resultMap>
  53. <resultMap type="com.ym.mec.biz.dal.dto.StudentMusicGroupDto" id="StudentMusicGroupDto"
  54. extends="StudentRegistration">
  55. <result column="music_group_quit_status_" property="musicGroupQuit.status"
  56. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  57. <result column="group_status_" property="musicGroup.status"
  58. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  59. <result column="music_group_name_" property="musicGroup.name"/>
  60. </resultMap>
  61. <resultMap type="com.ym.mec.biz.dal.dto.StudentInfo" id="StudentInfo">
  62. <result column="id_" property="id"/>
  63. <result column="username_" property="username"/>
  64. <result column="password_" property="password"/>
  65. <result column="salt_" property="salt"/>
  66. <result column="phone_" property="phone"/>
  67. <result column="avatar_" property="avatar"/>
  68. <result column="organ_id_" property="organId"/>
  69. <result column="create_time_" property="createTime"/>
  70. <result column="update_time_" property="updateTime"/>
  71. <result column="lock_flag_" property="lockFlag"/>
  72. <result column="del_flag_" property="delFlag" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  73. <result column="wx_openid_" property="wxOpenid"/>
  74. <result column="qq_openid_" property="qqOpenid"/>
  75. <result column="user_type_" property="userType"/>
  76. <result column="gender_" property="gender"/>
  77. <result column="nation_" property="nation"/>
  78. <result column="birthdate_" property="birthdate"/>
  79. <result column="email_" property="email"/>
  80. <result column="im_token_" property="imToken"/>
  81. <result column="id_card_no_" property="idCardNo"/>
  82. <result column="real_name_" property="realName"/>
  83. <result column="wechat_id_" property="wechatId"/>
  84. <result column="certificate_type_" property="certificateType"/>
  85. <result column="name_" property="name"/>
  86. <result column="parents_name_" property="parentsName"/>
  87. <result column="current_grade_" property="grade"/>
  88. <result column="current_grade_date_" property="gradeDate"/>
  89. <result column="current_class_" property="clazz"/>
  90. <result column="actual_subject_id_" property="subject.id"/>
  91. <result column="subject_name_" property="subject.name"/>
  92. </resultMap>
  93. <resultMap id="UserGroupDto" type="com.ym.mec.biz.dal.dto.UserGroupDto">
  94. <result column="user_id_" property="userId"/>
  95. <result column="group_id_" property="groupId"/>
  96. <result column="group_name_" property="groupName"/>
  97. </resultMap>
  98. <!-- 根据主键查询一条记录 -->
  99. <select id="get" resultMap="StudentRegistration">
  100. SELECT *
  101. FROM student_registration
  102. WHERE id_ = #{id}
  103. </select>
  104. <select id="lock" resultMap="StudentRegistration">
  105. SELECT *
  106. FROM student_registration
  107. WHERE id_ = #{id} FOR
  108. UPDATE
  109. </select>
  110. <select id="lockWithUserAndMusic" resultMap="StudentRegistration">
  111. SELECT *
  112. FROM student_registration
  113. WHERE user_id_ = #{userId}
  114. AND music_group_id_ = #{musicGroupId}
  115. AND music_group_status_ != 'QUIT' FOR
  116. UPDATE
  117. </select>
  118. <!-- 全查询 -->
  119. <select id="findAll" resultMap="StudentRegistration">
  120. SELECT *
  121. FROM student_registration
  122. ORDER BY id_
  123. </select>
  124. <!-- 向数据库增加一条记录 -->
  125. <insert id="insert" parameterType="com.ym.mec.biz.dal.entity.StudentRegistration" useGeneratedKeys="true"
  126. keyColumn="id" keyProperty="id">
  127. INSERT INTO student_registration
  128. <trim prefix="(" suffix=")" suffixOverrides=",">
  129. <if test="userId != null">
  130. user_id_,
  131. </if>
  132. <if test="name != null">
  133. name_,
  134. </if>
  135. <if test="musicGroupId != null">
  136. music_group_id_,
  137. </if>
  138. <if test="currentGrade != null">
  139. current_grade_,
  140. </if>
  141. <if test="currentGradeNum != null">
  142. current_grade_num_,
  143. </if>
  144. <if test="currentGradeDate != null">
  145. current_grade_date_,
  146. </if>
  147. <if test="currentClass != null">
  148. current_class_,
  149. </if>
  150. <if test="subjectId != null">
  151. subject_id_,
  152. </if>
  153. <if test="actualSubjectId != null">
  154. actual_subject_id_,
  155. </if>
  156. <if test="isAllowAdjust != null">
  157. is_allow_adjust_,
  158. </if>
  159. <if test="kitPurchaseMethod != null">
  160. kit_purchase_method_,
  161. </if>
  162. <if test="remark != null">
  163. remark_,
  164. </if>
  165. <if test="parentsName != null">
  166. parents_name_,
  167. </if>
  168. <if test="parentsPhone != null">
  169. parents_phone_,
  170. </if>
  171. <if test="parentsCompany != null">
  172. parents_company_,
  173. </if>
  174. <if test="paymentStatus != null">
  175. payment_status_,
  176. </if>
  177. <if test="classGroupId != null">
  178. class_group_id_,
  179. </if>
  180. <if test="musicGroupStatus != null">
  181. music_group_status_,
  182. </if>
  183. <if test="temporaryCourseFee != null">
  184. temporary_course_fee_,
  185. </if>
  186. <if test="surplusCourseFee != null">
  187. surplus_course_fee_,
  188. </if>
  189. <if test="createTime != null">
  190. create_time_,
  191. </if>
  192. <if test="updateTime != null">
  193. update_time_,
  194. </if>
  195. </trim>
  196. VALUES
  197. <trim prefix="(" suffix=")" suffixOverrides=",">
  198. <if test="userId != null">
  199. #{userId},
  200. </if>
  201. <if test="name != null">
  202. #{name},
  203. </if>
  204. <if test="musicGroupId != null">
  205. #{musicGroupId},
  206. </if>
  207. <if test="currentGrade != null">
  208. #{currentGrade},
  209. </if>
  210. <if test="currentGradeNum != null">
  211. #{currentGradeNum},
  212. </if>
  213. <if test="currentGradeDate != null">
  214. #{currentGradeDate},
  215. </if>
  216. <if test="currentClass != null">
  217. #{currentClass},
  218. </if>
  219. <if test="subjectId != null">
  220. #{subjectId},
  221. </if>
  222. <if test="actualSubjectId != null">
  223. #{actualSubjectId},
  224. </if>
  225. <if test="isAllowAdjust != null">
  226. #{isAllowAdjust,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  227. </if>
  228. <if test="kitPurchaseMethod != null">
  229. #{kitPurchaseMethod,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  230. </if>
  231. <if test="remark != null">
  232. #{remark},
  233. </if>
  234. <if test="parentsName != null">
  235. #{parentsName},
  236. </if>
  237. <if test="parentsPhone != null">
  238. #{parentsPhone},
  239. </if>
  240. <if test="parentsCompany != null">
  241. #{parentsCompany},
  242. </if>
  243. <if test="paymentStatus != null">
  244. #{paymentStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  245. </if>
  246. <if test="classGroupId != null">
  247. #{classGroupId},
  248. </if>
  249. <if test="musicGroupStatus != null">
  250. #{musicGroupStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  251. </if>
  252. <if test="temporaryCourseFee != null">
  253. #{temporaryCourseFee},
  254. </if>
  255. <if test="surplusCourseFee != null">
  256. #{surplusCourseFee},
  257. </if>
  258. <if test="createTime != null">
  259. NOW(),
  260. </if>
  261. <if test="updateTime != null">
  262. NOW(),
  263. </if>
  264. </trim>
  265. </insert>
  266. <!-- 根据主键更新一条记录 -->
  267. <update id="update" parameterType="com.ym.mec.biz.dal.entity.StudentRegistration">
  268. UPDATE student_registration
  269. <set>
  270. <if test="parentsPhone != null">
  271. parents_phone_ = #{parentsPhone},
  272. </if>
  273. <if test="subjectId != null">
  274. subject_id_ = #{subjectId},
  275. </if>
  276. <if test="currentGrade != null">
  277. current_grade_ = #{currentGrade},
  278. </if>
  279. <if test="currentGradeNum != null">
  280. current_grade_num_ = #{currentGradeNum},
  281. </if>
  282. <if test="currentGradeDate != null">
  283. current_grade_date_ = #{currentGradeDate},
  284. </if>
  285. <if test="currentClass != null">
  286. current_class_ = #{currentClass},
  287. </if>
  288. <if test="isAllowAdjust != null">
  289. is_allow_adjust_ = #{isAllowAdjust,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  290. </if>
  291. <if test="kitPurchaseMethod != null">
  292. kit_purchase_method_ = #{kitPurchaseMethod,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  293. </if>
  294. <if test="musicGroupStatus != null">
  295. music_group_status_ = #{musicGroupStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  296. </if>
  297. <if test="userId != null">
  298. user_id_ = #{userId},
  299. </if>
  300. <if test="name != null">
  301. name_ = #{name},
  302. </if>
  303. <if test="remark != null">
  304. remark_ = #{remark},
  305. </if>
  306. <if test="paymentStatus != null">
  307. payment_status_ = #{paymentStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  308. </if>
  309. <if test="parentsName != null">
  310. parents_name_ = #{parentsName},
  311. </if>
  312. <if test="updateTime != null">
  313. update_time_ = NOW(),
  314. </if>
  315. <if test="createTime != null">
  316. create_time_ = #{createTime},
  317. </if>
  318. <if test="parentsCompany != null">
  319. parents_company_ = #{parentsCompany},
  320. </if>
  321. <if test="musicGroupId != null">
  322. music_group_id_ = #{musicGroupId},
  323. </if>
  324. <if test="actualSubjectId != null">
  325. actual_subject_id_ = #{actualSubjectId},
  326. </if>
  327. <if test="classGroupId != null">
  328. class_group_id_ = #{classGroupId},
  329. </if>
  330. <if test="temporaryCourseFee != null">
  331. temporary_course_fee_ =#{temporaryCourseFee},
  332. </if>
  333. <if test="surplusCourseFee != null">
  334. surplus_course_fee_ =#{surplusCourseFee},
  335. </if>
  336. <if test="payingStatus != null">
  337. paying_status_ =#{payingStatus},
  338. </if>
  339. <if test="hasCloudTeacher != null">
  340. has_cloud_teacher_ =#{hasCloudTeacher},
  341. </if>
  342. <if test="noneNeedCloudTeacher != null">
  343. none_need_cloud_teacher_ =#{noneNeedCloudTeacher},
  344. </if>
  345. </set>
  346. WHERE id_ = #{id}
  347. </update>
  348. <!-- 根据主键删除一条记录 -->
  349. <delete id="delete">
  350. DELETE
  351. FROM student_registration
  352. WHERE id_ = #{id}
  353. </delete>
  354. <sql id="queryPageSql">
  355. <where>
  356. <if test="isAllowAdjust != null">
  357. AND is_allow_adjust_ = #{isAllowAdjust,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}
  358. </if>
  359. <if test="subjectId != null">
  360. AND subject_id_ = #{subjectId}
  361. </if>
  362. </where>
  363. </sql>
  364. <!-- 分页查询 -->
  365. <select id="queryPage" resultMap="StudentRegistration" parameterType="map">
  366. SELECT *
  367. FROM student_registration
  368. ORDER BY id_
  369. <include refid="global.limit"/>
  370. </select>
  371. <!-- 查询当前表的总记录数 -->
  372. <select id="queryCount" resultType="int">
  373. SELECT COUNT(*)
  374. FROM student_registration
  375. </select>
  376. <sql id="queryStudentDetailPageSql">
  377. <where>
  378. sr.music_group_status_ != 'QUIT'
  379. <if test="musicGroupId != null">
  380. AND sr.music_group_id_ = #{musicGroupId}
  381. </if>
  382. <if test="subjectId != null">
  383. AND sr.subject_id_ = #{subjectId}
  384. </if>
  385. <if test="isAllowAdjust != null">
  386. AND sr.is_allow_adjust_ = #{isAllowAdjust}
  387. </if>
  388. <if test="actualSubjectId != null">
  389. AND sr.actual_subject_id_ = #{actualSubjectId}
  390. </if>
  391. <if test="paymentStatus != null">
  392. AND sr.payment_status_ = #{paymentStatus}
  393. </if>
  394. <if test="visited != null and visited == true">
  395. AND sv.num >0
  396. </if>
  397. <if test="visited != null and visited == false">
  398. AND sv.num IS NULL
  399. </if>
  400. <if test="name != null">
  401. AND (su.username_ LIKE CONCAT('%',#{name},'%') OR sr.parents_phone_ LIKE CONCAT('%',#{name},'%'))
  402. </if>
  403. <if test="currentGrade != null">
  404. AND sr.current_grade_ LIKE CONCAT('%',#{currentGrade},'%')
  405. </if>
  406. <if test="createYear != null">
  407. AND DATE_FORMAT(sr.create_time_,'%Y') = #{createYear}
  408. </if>
  409. <if test="hasCloudTeacher != null">
  410. AND sr.has_cloud_teacher_ = #{hasCloudTeacher}
  411. </if>
  412. <if test="payingStatus != null">
  413. AND sr.paying_status_ = #{payingStatus}
  414. </if>
  415. <if test="noneNeedCloudTeacher != null">
  416. AND sr.none_need_cloud_teacher_ = #{noneNeedCloudTeacher}
  417. </if>
  418. </where>
  419. </sql>
  420. <resultMap type="com.ym.mec.biz.dal.dto.StudentApplyDetailDto" id="studentApplyDetail">
  421. <result column="current_grade_" property="currentGrade"/>
  422. <result column="current_grade_date_" property="currentGradeDate"/>
  423. <result column="current_class_" property="currentClass"/>
  424. <result column="is_allow_adjust_" property="isAllowAdjust"
  425. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  426. <result column="parents_name_" property="parentsName"/>
  427. <result column="parents_phone_" property="parentsPhone"/>
  428. <result column="subject_name_" property="subjectName"/>
  429. <result column="actual_subject_id_" property="actualSubjectId"/>
  430. <result column="username_" property="studentName"/>
  431. <result column="actual_subject_name_" property="actualSubjectName"/>
  432. <result column="payment_status_" property="paymentStatus"
  433. typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  434. <result column="gender_" property="gender" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  435. <result column="user_id_" property="studentId"/>
  436. <result column="id_" property="id"/>
  437. <result column="remark_" property="remark"/>
  438. <result column="create_time_" property="createTime"/>
  439. <result column="visit_num_" property="visitNum"/>
  440. <result column="paying_status_" property="payingStatus"/>
  441. <result column="has_cloud_teacher_" property="hasCloudTeacher"/>
  442. <result column="none_need_cloud_teacher_" property="noneNeedCloudTeacher"/>
  443. </resultMap>
  444. <select id="queryStudentDetailPage" resultMap="studentApplyDetail">
  445. SELECT sr.id_,
  446. sr.create_time_,
  447. sr.user_id_,
  448. su.username_ username_,
  449. sr.parents_name_,
  450. sr.current_class_,
  451. sr.current_grade_,
  452. sr.current_grade_date_,
  453. su.gender_,
  454. sr.is_allow_adjust_,
  455. s.name_ subject_name_,
  456. ss.name_
  457. actual_subject_name_,
  458. su.phone_ parents_phone_,
  459. sr.payment_status_,
  460. sr.remark_,
  461. sr.actual_subject_id_,
  462. IFNULL(sv.num, 0) visit_num_,
  463. sr.has_cloud_teacher_,
  464. sr.paying_status_,
  465. sr.none_need_cloud_teacher_
  466. FROM student_registration sr
  467. LEFT JOIN sys_user su ON sr.user_id_ = su.id_
  468. LEFT JOIN `subject` s ON sr.subject_id_ = s.id_
  469. LEFT JOIN `subject` ss ON sr.actual_subject_id_ = ss.id_
  470. LEFT JOIN (
  471. SELECT v.student_id_, COUNT(*) num
  472. FROM student_visit v
  473. WHERE v.music_group_id_ = #{musicGroupId}
  474. GROUP BY v.student_id_
  475. ) sv ON sv.student_id_ = sr.user_id_
  476. <include refid="queryStudentDetailPageSql"/>
  477. <include refid="global.limit"/>
  478. </select>
  479. <select id="queryStudentDetailCount" resultType="java.lang.Integer">
  480. SELECT COUNT(sr.id_)
  481. FROM student_registration sr
  482. LEFT JOIN sys_user su ON sr.user_id_ = su.id_
  483. LEFT JOIN (
  484. SELECT v.student_id_, COUNT(*) num
  485. FROM student_visit v
  486. WHERE v.music_group_id_ = #{musicGroupId}
  487. GROUP BY v.student_id_
  488. ) sv on sv.student_id_ = sr.user_id_
  489. <include refid="queryStudentDetailPageSql"/>
  490. </select>
  491. <select id="countPayNum" resultType="map">
  492. SELECT COUNT(DISTINCT user_id_) `value`, actual_subject_id_ `key`
  493. FROM student_registration
  494. WHERE music_group_id_ = #{musicGroupId}
  495. AND payment_status_ = 2
  496. AND music_group_status_ != 'QUIT'
  497. GROUP BY actual_subject_id_
  498. </select>
  499. <resultMap id="queryFeeDetailMap" type="com.ym.mec.biz.dal.dto.StudentFeeDetailDto">
  500. <result column="actual_amount_" property="totalAmount"/>
  501. <collection property="goods" ofType="com.ym.mec.biz.dal.dto.StudentFeeDto">
  502. <result property="goodsName" column="goods_name_"/>
  503. <result property="goodsType" column="type_"/>
  504. <result property="musicalFee" column="price_"/>
  505. </collection>
  506. </resultMap>
  507. <select id="queryFeeDetail" resultMap="queryFeeDetailMap">
  508. SELECT spo.actual_amount_,
  509. SUM(spod.price_) price_,
  510. GROUP_CONCAT(g.name_) goods_name_,
  511. IF(MAX(g.type_) IS NULL, 'COURSE', MAX(g.type_)) type_
  512. FROM student_payment_order spo
  513. LEFT JOIN student_payment_order_detail spod ON spod.payment_order_id_ = spo.id_
  514. LEFT JOIN goods g ON FIND_IN_SET(g.id_, spod.goods_id_list_)
  515. WHERE spo.type_ = 'APPLY'
  516. AND spo.group_type_ = 'MUSIC'
  517. AND spo.user_id_ = #{studentId}
  518. AND spo.music_group_id_ = #{musicGroupId}
  519. AND spo.status_ = 'SUCCESS'
  520. GROUP BY spo.id_, spod.type_
  521. ORDER BY spo.id_ DESC
  522. LIMIT 1
  523. </select>
  524. <!-- 根据乐团和声部获取未分班的学生 -->
  525. <select id="getNoClassStuBySubjectId" resultMap="StudentRegistration">
  526. SELECT *
  527. FROM student_registration
  528. WHERE music_group_id_ = #{musicGroupId}
  529. AND payment_status_ = 2
  530. AND (class_group_id_ = 0 OR class_group_id_ IS NULL)
  531. AND music_group_status_ != 'QUIT'
  532. <if test="actualSubjectId != null">
  533. AND FIND_IN_SET(actual_subject_id_, #{actualSubjectId})
  534. </if>
  535. </select>
  536. <resultMap type="com.ym.mec.biz.dal.entity.MusicGroupSubjectPlan" id="getNoClassStuCountByMusicGroupId">
  537. <result column="actual_subject_id_" property="subjectId"/>
  538. <result column="nums" property="noClassStudentNum"/>
  539. </resultMap>
  540. <!-- 根据乐团和声部获取未分班人数 -->
  541. <select id="getNoClassStuCountByMusicGroupId" resultMap="getNoClassStuCountByMusicGroupId">
  542. SELECT actual_subject_id_, COUNT(*) nums
  543. FROM student_registration
  544. WHERE music_group_id_ = #{musicGroupId}
  545. AND payment_status_ = 2
  546. AND (class_group_id_ = 0 OR class_group_id_ IS NULL)
  547. AND music_group_status_ != 'QUIT'
  548. GROUP BY actual_subject_id_
  549. </select>
  550. <update id="updateByUserIdAndMusicGroupId" parameterType="com.ym.mec.biz.dal.entity.StudentRegistration">
  551. UPDATE student_registration
  552. SET class_group_id_ = #{studentRegistration.classGroupId}
  553. WHERE user_id_ =
  554. #{studentRegistration.userId}
  555. AND music_group_id_ = #{studentRegistration.musicGroupId}
  556. </update>
  557. <update id="batchUpdateSubject">
  558. UPDATE student_registration
  559. SET actual_subject_id_ = #{subId},
  560. update_time_ = now()
  561. WHERE user_id_ = #{userId}
  562. AND payment_status_ != 2
  563. AND music_group_id_ = #{musicGroupId}
  564. </update>
  565. <select id="queryStudentInfo" resultMap="StudentInfo">
  566. SELECT sut.name_ real_name_,
  567. sut.card_no_ id_card_no_,
  568. u.*,
  569. sr.name_,
  570. sr.current_class_,
  571. sr.current_grade_,
  572. sr.actual_subject_id_,
  573. sr.parents_name_,
  574. s.name_ subject_name_
  575. FROM sys_user u
  576. LEFT JOIN student_registration sr ON u.id_ = sr.user_id_
  577. LEFT JOIN subject s ON sr.actual_subject_id_ = s.id_
  578. LEFT JOIN sys_user_tsign sut ON sut.user_id_ = u.id_
  579. WHERE u.id_ = #{userId}
  580. ORDER BY sr.create_time_ DESC
  581. limit 1
  582. </select>
  583. <select id="queryByUserIdAndMusicGroupId" resultMap="StudentRegistration">
  584. SELECT sr.*, su.id_card_no_, su.organ_id_
  585. FROM student_registration sr
  586. LEFT JOIN sys_user su ON su.id_ = sr.user_id_
  587. WHERE sr.music_group_id_ = #{musicGroupId}
  588. AND sr.user_id_ = #{userId}
  589. AND sr.music_group_status_ != 'QUIT'
  590. LIMIT 1
  591. </select>
  592. <!-- 根据乐团编号和手机号查询注册乐团注册信息-->
  593. <select id="getByPhoneAndMusicGroupId" resultMap="StudentRegistration">
  594. SELECT *
  595. FROM student_registration
  596. WHERE music_group_id_ = #{musicGroupId}
  597. AND parents_phone_ = #{parentsPhone}
  598. </select>
  599. <resultMap type="com.ym.mec.auth.api.entity.SysUser" id="FindSysUser">
  600. <result column="id_" property="id"/>
  601. <result column="username_" property="username"/>
  602. <result column="password_" property="password"/>
  603. <result column="salt_" property="salt"/>
  604. <result column="phone_" property="phone"/>
  605. <result column="avatar_" property="avatar"/>
  606. <result column="organ_id_" property="organId"/>
  607. <result column="create_time_" property="createTime"/>
  608. <result column="update_time_" property="updateTime"/>
  609. <result column="lock_flag_" property="lockFlag"/>
  610. <result column="del_flag_" property="delFlag" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
  611. <result column="wx_openid_" property="wxOpenid"/>
  612. <result column="qq_openid_" property="qqOpenid"/>
  613. <result column="user_type_" property="userType"/>
  614. <result column="gender_" property="gender"/>
  615. <result column="nation_" property="nation"/>
  616. <result column="birthdate_" property="birthdate"/>
  617. <result column="email_" property="email"/>
  618. <result column="im_token_" property="imToken"/>
  619. <result column="id_card_no_" property="idCardNo"/>
  620. <result column="wechat_id_" property="wechatId"/>
  621. </resultMap>
  622. <select id="getSysUserByPhone" resultMap="FindSysUser">
  623. SELECT *
  624. FROM sys_user
  625. WHERE phone_ = #{phone}
  626. LIMIT 1
  627. </select>
  628. <!-- 获取班级下的学生 -->
  629. <select id="findClassGroupStu" resultMap="StudentRegistration">
  630. SELECT *
  631. FROM student_registration
  632. WHERE music_group_id_ = #{musicGroupId}
  633. AND music_group_status_ != 'QUIT'
  634. <if test="classGroupId != null">
  635. AND class_group_id_ = #{classGroupId}
  636. </if>
  637. </select>
  638. <!-- 根据班级和userId查询学生信息-->
  639. <select id="findStudentByClassGroupIdAndUserId" resultMap="StudentRegistration">
  640. SELECT *
  641. FROM student_registration
  642. WHERE user_id_ = #{userId}
  643. AND class_group_id_ = #{classGroupId}
  644. AND music_group_status_ != 'QUIT'
  645. </select>
  646. <!-- 获取乐团未分班的学生 -->
  647. <select id="findMusicGroupNoClassGroupStudent" resultMap="StudentRegistration">
  648. SELECT *
  649. FROM student_registration WHERE music_group_id_ = #{musicGroupId}
  650. <if test="actualSubjectId != null">
  651. AND actual_subject_id_ = #{actualSubjectId}
  652. </if>
  653. AND payment_status_ = 2
  654. AND (class_group_id_ = 0 OR class_group_id_ IS NULL)
  655. AND music_group_status_ != 'QUIT'
  656. </select>
  657. <!-- 获取乐团声部下的学生 -->
  658. <select id="findMusicGroupStudent" resultMap="StudentRegistration">
  659. SELECT sr.*, cg.name_ class_group_name_, su.gender_ gender_, su.username_
  660. FROM student_registration sr
  661. LEFT JOIN class_group cg ON cg.id_ = sr.class_group_id_
  662. LEFT JOIN sys_user su on sr.user_id_ = su.id_
  663. LEFT JOIN sys_user_tsign sut ON sut.user_id_ = su.id_
  664. WHERE sr.music_group_id_ = #{musicGroupId}
  665. <if test="actualSubjectId != null">
  666. AND FIND_IN_SET(sr.actual_subject_id_, #{actualSubjectId})
  667. </if>
  668. AND payment_status_ = 2
  669. AND sr.music_group_status_ != 'QUIT'
  670. </select>
  671. <!-- 根据注册id list查询报名学生的信息 -->
  672. <select id="findStudentListByIdList" resultMap="StudentRegistration">
  673. SELECT *
  674. FROM student_registration WHERE id_ IN
  675. <foreach collection="idList" item="id" index="index" open="(" close=")" separator=",">
  676. #{id}
  677. </foreach>
  678. AND music_group_status_ != 'QUIT'
  679. </select>
  680. <insert id="batchInsert" parameterType="list" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
  681. INSERT INTO student_registration
  682. (parents_phone_, id_, user_id_, name_, music_group_id_, current_grade_, current_class_, subject_id_,
  683. is_allow_adjust_, kit_purchase_method_, remark_, create_time_, update_time_,
  684. parents_name_, parents_company_, payment_status_, actual_subject_id_, music_group_status_, is_merge_)
  685. VALUES
  686. <foreach collection="list" item="item" index="index" separator=",">
  687. (#{item.parentsPhone}, #{item.id}, #{item.userId}, #{item.name}, #{item.musicGroupId}, #{item.currentGrade},
  688. #{item.currentClass}, #{item.subjectId},
  689. #{item.isAllowAdjust,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  690. #{item.kitPurchaseMethod,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  691. #{item.remark}, now(), now(), #{item.parentsName}, #{item.parentsCompany},
  692. #{item.paymentStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}, #{item.subjectId},
  693. #{item.musicGroupStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}, #{item.isMerge})
  694. </foreach>
  695. </insert>
  696. <insert id="insertBasic" parameterType="com.ym.mec.biz.dal.entity.StudentRegistration" useGeneratedKeys="true"
  697. keyColumn="id" keyProperty="id">
  698. INSERT INTO student_registration
  699. (parents_phone_, user_id_, name_, music_group_id_, current_grade_, current_class_, subject_id_,
  700. create_time_, update_time_, parents_name_, payment_status_, actual_subject_id_, music_group_status_,
  701. temporary_course_fee_, class_group_id_,current_grade_num_,current_grade_date_)
  702. VALUES (#{parentsPhone}, #{userId}, #{name}, #{musicGroupId}, #{currentGrade}, #{currentClass}, #{subjectId},
  703. now(), now(), #{parentsName}, #{paymentStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  704. #{subjectId},
  705. #{musicGroupStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}, #{temporaryCourseFee},
  706. #{classGroupId},#{currentGradeNum},#{currentGradeDate})
  707. </insert>
  708. <!-- 查询乐团userIdList的学生 -->
  709. <select id="findStudentListByUserIdList" resultMap="StudentRegistration">
  710. SELECT *
  711. FROM student_registration WHERE music_group_id_ = #{musicGroupId}
  712. AND music_group_status_ != 'QUIT'
  713. AND user_id_ IN
  714. <foreach collection="userIdList" item="userId" index="index" open="(" close=")" separator=",">
  715. #{userId}
  716. </foreach>
  717. </select>
  718. <select id="countApplyNum" resultType="java.util.Map">
  719. SELECT sr.actual_subject_id_ 'key', COUNT(DISTINCT sr.user_id_) 'value'
  720. FROM student_registration sr
  721. WHERE sr.music_group_id_ = #{musicGroupId}
  722. AND sr.music_group_status_ != 'QUIT'
  723. GROUP BY actual_subject_id_
  724. </select>
  725. <select id="findParentId" resultType="map">
  726. SELECT MAX(sr.user_id_) `key`, sr.parents_phone_ `value`
  727. FROM student_registration sr
  728. WHERE FIND_IN_SET(sr.parents_phone_, #{parentPhones})
  729. AND sr.music_group_status_ != 'QUIT'
  730. GROUP BY sr.parents_phone_
  731. </select>
  732. <select id="queryStudentByMusicGroupId" resultMap="StudentRegistration">
  733. SELECT *
  734. FROM student_registration sr
  735. WHERE sr.music_group_id_ = #{musicGroupId}
  736. AND sr.payment_status_ = 2
  737. AND sr.music_group_status_ != 'QUIT'
  738. </select>
  739. <!-- 批量开启缴费 -->
  740. <update id="batchOpenPay">
  741. UPDATE student_registration
  742. SET payment_status_ = #{paymentStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  743. update_time_ = now()
  744. WHERE FIND_IN_SET(id_, #{ids})
  745. AND payment_status_ = '0'
  746. </update>
  747. <!-- 乐团批量开启缴费 -->
  748. <update id="musicGroupOpenPay">
  749. UPDATE student_registration
  750. SET payment_status_ = #{paymentStatus,typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler},
  751. update_time_ = now()
  752. WHERE music_group_id_ = #{musicGroupId}
  753. AND payment_status_ = '0'
  754. </update>
  755. <select id="queryStudentNum" resultType="map">
  756. SELECT count(distinct sr.user_id_) total_num_,
  757. sum(case
  758. when sr.create_time_ >= timestamp(date_add(curdate(), interval - day(curdate()) + 1 day)) then 1
  759. else 0 end) new_num_,
  760. sum(case
  761. when sr.music_group_status_ = 'QUIT' and
  762. sr.update_time_ >= timestamp(date_add(curdate(), interval - day(curdate()) + 1 day)) then 1
  763. else 0 end) quit_num_
  764. FROM student_registration sr
  765. left join music_group mg on sr.music_group_id_ = mg.id_
  766. where mg.organ_id_ not in (36, 38)
  767. <if test="organId != null">
  768. AND FIND_IN_SET(mg.organ_id_, #{organId})
  769. </if>
  770. </select>
  771. <select id="findMapByMusicGroupId" resultType="java.util.Map">
  772. SELECT sr.user_id_ 'key', MIN(sr.parents_phone_) 'value'
  773. FROM student_registration sr
  774. WHERE sr.music_group_id_ = #{musicGroupId}
  775. AND sr.music_group_status_ != 'QUIT'
  776. <if test="paymentStatus != null">
  777. AND sr.payment_status_ = #{paymentStatus}
  778. </if>
  779. GROUP BY sr.user_id_
  780. </select>
  781. <select id="findIdMapByMusicGroupId" resultType="java.util.Map">
  782. SELECT sr.user_id_ 'key', MIN(sr.user_id_) 'value'
  783. FROM student_registration sr
  784. WHERE sr.music_group_id_ = #{musicGroupId}
  785. AND sr.music_group_status_ != 'QUIT'
  786. <if test="paymentStatus != null">
  787. AND sr.payment_status_ = #{paymentStatus}
  788. </if>
  789. GROUP BY sr.user_id_
  790. </select>
  791. <!-- 删除学生的班级 -->
  792. <update id="deleteClassGroup">
  793. UPDATE student_registration
  794. SET class_group_id_ = 0,
  795. update_time_ = now()
  796. WHERE class_group_id_ = #{classGroupId}
  797. </update>
  798. <!-- 获取乐团学生人数 -->
  799. <select id="findMusicGroupStudentNum" resultType="integer">
  800. SELECT Count(*)
  801. FROM student_registration
  802. WHERE music_group_id_ = #{musicGroupId}
  803. AND payment_status_ = '2'
  804. AND music_group_status_ != 'QUIT'
  805. </select>
  806. <select id="countNormalNum" resultType="java.util.Map">
  807. SELECT sr.music_group_id_ 'key', COUNT(DISTINCT sr.user_id_) 'value'
  808. FROM student_registration sr
  809. WHERE sr.payment_status_ = 2
  810. AND sr.music_group_status_ != 'QUIT'
  811. AND FIND_IN_SET(sr.music_group_id_, #{musicGroupIds})
  812. GROUP BY sr.music_group_id_
  813. </select>
  814. <select id="queryNormalUser" resultType="integer">
  815. SELECT sr.user_id_
  816. FROM student_registration sr
  817. WHERE sr.music_group_status_ != 'QUIT'
  818. AND sr.music_group_id_ = #{musicGroupIds}
  819. </select>
  820. <select id="queryNormalUserList" resultType="integer">
  821. SELECT sr.user_id_
  822. FROM student_registration sr
  823. WHERE sr.music_group_status_ = 'NORMAL'
  824. AND sr.music_group_id_ = #{musicGroupIds}
  825. </select>
  826. <select id="queryUserByPhone" resultMap="StudentRegistration">
  827. SELECT su.id_,
  828. CASE WHEN sut.name_ IS NULL THEN su.real_name_ ELSE sut.name_ END parents_name_,
  829. su.phone_,
  830. sr.current_grade_,
  831. sr.current_grade_num_,
  832. sr.current_class_,
  833. su.username_ name_,
  834. su.birthdate_,
  835. su.gender_
  836. FROM sys_user su
  837. LEFT JOIN sys_user_tsign sut ON sut.user_id_ = su.id_
  838. LEFT JOIN student_registration sr ON sr.user_id_ = su.id_
  839. WHERE su.phone_ = #{mobile}
  840. ORDER BY sr.id_ DESC
  841. LIMIT 1
  842. </select>
  843. <select id="queryPurchaseTypeMap" resultType="java.util.Map">
  844. SELECT sr.user_id_ 'key', mgsp.kit_group_purchase_type_ 'value'
  845. FROM student_registration sr
  846. LEFT JOIN music_group_subject_plan mgsp
  847. ON sr.actual_subject_id_ = mgsp.subject_id_ AND sr.music_group_id_ = mgsp.music_group_id_
  848. WHERE sr.music_group_id_ = #{musicGroupId}
  849. </select>
  850. <resultMap id="StudentRegisterPerDtoMap" type="com.ym.mec.biz.dal.dto.StudentRegisterPerDto">
  851. <result property="organName" column="organ_name_"/>
  852. <result property="studentNum" column="student_num_"/>
  853. <result property="per" column="per_"/>
  854. <result property="perNum" column="per_num_"/>
  855. </resultMap>
  856. <select id="queryStudentPer1" resultMap="StudentRegisterPerDtoMap">
  857. SELECT o.name_ organ_name_, md.total_num_ student_num_, md.activate_num_ per_num_, md.percent_ per_
  858. FROM index_base_month_data md
  859. LEFT JOIN organization o ON o.id_ = md.organ_id_
  860. WHERE data_type_ = 'ACTIVATION_RATE'
  861. AND month_ = #{month}
  862. ORDER BY md.percent_ DESC, o.id_
  863. </select>
  864. <select id="queryStudentPer" resultMap="StudentRegisterPerDtoMap">
  865. SELECT a.name_ organ_name_, a.num_ student_num_, b.num_ per_num_, ifnull(b.num_, 0) * 100 / a.num_ per_
  866. FROM (SELECT o.id_, o.name_, COUNT(DISTINCT su.id_) num_
  867. FROM sys_user su
  868. LEFT JOIN organization o ON su.organ_id_ = o.id_
  869. WHERE su.user_type_ LIKE '%STUDENT%'
  870. AND su.id_ IN
  871. <foreach collection="userIds" separator="," open="(" close=")" item="item">
  872. #{item}
  873. </foreach>
  874. GROUP BY su.organ_id_) a
  875. LEFT JOIN
  876. (SELECT su.organ_id_ id_, COUNT(DISTINCT su.id_) num_
  877. FROM sys_user su
  878. WHERE su.user_type_ LIKE '%STUDENT%'
  879. AND su.password_ IS NOT NULL
  880. AND su.id_ IN
  881. <foreach collection="userIds" separator="," open="(" close=")" item="item">
  882. #{item}
  883. </foreach>
  884. GROUP BY su.organ_id_) b
  885. ON a.id_ = b.id_
  886. ORDER BY per_ DESC
  887. </select>
  888. <update id="updateUser">
  889. UPDATE sys_user
  890. <set>
  891. <if test="name != null">
  892. username_ = #{name},
  893. </if>
  894. <if test="realName != null">
  895. real_name_ = #{realName},
  896. </if>
  897. <if test="idCardNo != null">
  898. id_card_no_ = #{idCardNo},
  899. </if>
  900. <if test="certificateType != null">
  901. certificate_type_ = #{certificateType},
  902. </if>
  903. <if test="gender != null">
  904. gender_ = #{gender},
  905. </if>
  906. update_time_=NOW()
  907. WHERE id_ = #{id}
  908. </set>
  909. </update>
  910. <update id="updateCurrentClass" parameterType="com.ym.mec.biz.dal.entity.StudentRegistration">
  911. UPDATE student_registration sr
  912. SET sr.current_grade_ = #{currentGrade},
  913. sr.current_class_ = #{currentClass},
  914. sr.current_grade_date_= NOW(),
  915. sr.update_time_ = NOW()
  916. WHERE sr.user_id_ = #{userId}
  917. </update>
  918. <update id="updatePaymentStatusByClaenderId">
  919. UPDATE student_registration sr
  920. LEFT JOIN music_group_payment_calender mgpc ON mgpc.music_group_id_ = sr.music_group_id_
  921. LEFT JOIN music_group_payment_calender_detail mgpcd ON mgpc.id_ = mgpcd.music_group_payment_calender_id_
  922. SET sr.payment_status_ = 2,
  923. sr.music_group_status_ = 'NORMAL',
  924. sr.update_time_ = NOW()
  925. WHERE mgpcd.user_id_ = sr.user_id_
  926. AND mgpcd.expect_amount_ = 0
  927. AND mgpc.id_ = #{calenderId}
  928. </update>
  929. <select id="findStudentByMusicGroupIdAndUserId" resultMap="StudentRegistration">
  930. SELECT s.name_ school_name_, s2.name_ subject_name_, co.name_ remark_, su.real_name_ name_
  931. FROM student_registration sr
  932. LEFT JOIN music_group mg ON mg.id_ = sr.music_group_id_
  933. LEFT JOIN school s ON mg.school_id_ = s.id_
  934. LEFT JOIN subject s2 ON sr.actual_subject_id_ = s2.id_
  935. LEFT JOIN cooperation_organ co ON mg.cooperation_organ_id_ = co.id_
  936. LEFT JOIN sys_user su on mg.educational_teacher_id_ = su.id_
  937. WHERE sr.music_group_id_ = #{musicGroupId}
  938. AND sr.user_id_ = #{userId}
  939. AND sr.payment_status_ = 2
  940. ORDER BY sr.id_ DESC
  941. LIMIT 1
  942. </select>
  943. <select id="queryStudentMusicGroup" resultType="java.lang.String">
  944. SELECT DISTINCT sr.music_group_id_
  945. FROM student_registration sr
  946. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  947. WHERE sr.user_id_ = #{studentId}
  948. AND sr.music_group_status_ != 'QUIT'
  949. AND mg.status_ = 'PROGRESS'
  950. </select>
  951. <select id="getSubjectIds" resultType="java.lang.String">
  952. SELECT GROUP_CONCAT(sr.subject_id_)
  953. FROM student_registration sr
  954. WHERE sr.music_group_status_ != 'QUIT'
  955. AND sr.user_id_ = #{userId}
  956. GROUP BY sr.user_id_
  957. </select>
  958. <select id="findMusicGroupAllStudentSubjects" resultMap="com.ym.mec.biz.dal.dao.SubjectDao.Subject">
  959. SELECT DISTINCT s.*
  960. FROM student_registration sr
  961. LEFT JOIN subject s ON sr.actual_subject_id_ = s.id_
  962. WHERE sr.music_group_id_ = #{musicGroupId}
  963. ORDER BY s.id_
  964. </select>
  965. <resultMap id="getStudentDetail" type="com.ym.mec.biz.dal.dto.StudentMusicDetailDto">
  966. <result property="gender" column="gender_"/>
  967. <result property="username" column="username_"/>
  968. <result property="userId" column="id_"/>
  969. <result property="phone" column="phone_"/>
  970. <result property="avatar" column="avatar_"/>
  971. <result property="imToken" column="im_token_"/>
  972. <collection property="musicGroups" ofType="com.ym.mec.biz.dal.entity.MusicGroup">
  973. <result property="name" column="music_group_name_"/>
  974. <result column="music_group_id_" property="id"/>
  975. <result column="subject_name_" property="subjectName"/>
  976. </collection>
  977. </resultMap>
  978. <select id="getStudentDetail" resultMap="getStudentDetail">
  979. SELECT su.username_,
  980. su.gender_,
  981. su.phone_,
  982. su.avatar_,
  983. su.id_,
  984. su.im_token_,
  985. mg.name_ music_group_name_,
  986. mg.id_ music_group_id_,
  987. sj.name_ subject_name_
  988. FROM student s
  989. LEFT JOIN music_group_student_fee_ mgsf ON mgsf.user_id_ = s.user_id_
  990. LEFT JOIN music_group mg ON mg.id_ = mgsf.music_group_id_
  991. LEFT JOIN `subject` sj ON sj.id_ = mgsf.subject_id_
  992. LEFT JOIN sys_user su ON su.id_ = s.user_id_
  993. WHERE s.user_id_ = #{studentId}
  994. </select>
  995. <select id="getMusicGroupStu" resultMap="StudentRegistration">
  996. SELECT sr.user_id_, s.username_ name_, sr.music_group_status_,st.membership_end_time_
  997. FROM student_registration sr
  998. LEFT JOIN sys_user s on sr.user_id_ = s.id_
  999. LEFT JOIN student st on st.user_id_ = s.id_
  1000. WHERE music_group_id_ = #{musicGroupId}
  1001. </select>
  1002. <select id="getMusicGroupStu4Teacher" resultMap="StudentRegistration">
  1003. SELECT s.id_ user_id_, s.username_ name_
  1004. FROM course_schedule cs
  1005. LEFT JOIN course_schedule_student_payment cssp ON cssp.course_schedule_id_ = cs.id_
  1006. LEFT JOIN sys_user s ON s.id_ = cssp.user_id_
  1007. WHERE cs.music_group_id_ = #{musicGroupId}
  1008. AND cs.actual_teacher_id_ = #{teacherId}
  1009. AND cs.group_type_ = 'MUSIC'
  1010. GROUP BY s.id_
  1011. </select>
  1012. <select id="getStudentRegister" resultMap="StudentRegistration">
  1013. SELECT *
  1014. FROM student_registration
  1015. WHERE music_group_id_ = #{musicGroupId}
  1016. AND user_id_ = #{studentId}
  1017. ORDER BY id_ DESC
  1018. LIMIT 1
  1019. </select>
  1020. <!-- 获取分部乐团在读人数 -->
  1021. <select id="getOrganNormalStudent" resultMap="com.ym.mec.biz.dal.dao.StudentPaymentOrderDao.luckStatis">
  1022. SELECT mg.organ_id_ organId, COUNT(DISTINCT sr.user_id_) estimatedNums
  1023. FROM student_registration sr
  1024. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1025. WHERE sr.music_group_status_ = 'NORMAL'
  1026. GROUP BY mg.organ_id_
  1027. </select>
  1028. <select id="getUserGroups" resultMap="UserGroupDto">
  1029. SELECT DISTINCT sr.user_id_, mg.id_ group_id_, mg.name_ group_name_
  1030. FROM student_registration sr
  1031. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1032. WHERE sr.payment_status_ = 2
  1033. AND sr.music_group_status_ = 'NORMAL'
  1034. AND sr.user_id_ IN
  1035. <foreach collection="userIds" item="userId" open="(" close=")" separator=",">
  1036. #{userId}
  1037. </foreach>
  1038. </select>
  1039. <select id="getNoPaymentStudent" resultMap="StudentRegistration">
  1040. SELECT *
  1041. FROM student_registration
  1042. WHERE music_group_id_ = #{musicGroupId}
  1043. AND payment_status_ IN (0, 1)
  1044. </select>
  1045. <!-- 获取乐团声部学生数量 -->
  1046. <select id="getMusicGroupSubjectStudentNum" resultType="int">
  1047. SELECT COUNT(*)
  1048. FROM student_registration
  1049. WHERE music_group_id_ = #{musicGroupId}
  1050. AND INTE_ARRAY(actual_subject_id_, #{subjectIds})
  1051. AND music_group_status_ = 'NORMAL'
  1052. </select>
  1053. <select id="queryStudentMusicGroupInfo" resultMap="StudentMusicGroupDto">
  1054. select sr.*,
  1055. s.name_ subject_name_,
  1056. mg.status_ group_status_,
  1057. mg.name_ music_group_name_,
  1058. mgq.status_ music_group_quit_status_
  1059. from student_registration sr
  1060. left join subject s on s.id_ = sr.actual_subject_id_
  1061. left join music_group mg on sr.music_group_id_ = mg.id_
  1062. left join (select mgq.*
  1063. from music_group_quit mgq
  1064. where mgq.id_ in
  1065. (select max(id_) from music_group_quit group by music_group_id_, user_id_)) mgq
  1066. ON mgq.music_group_id_ = sr.music_group_id_
  1067. AND mgq.user_id_ = sr.user_id_ AND mgq.join_date_ = sr.create_time_
  1068. where sr.user_id_ = #{userId}
  1069. order by sr.id_
  1070. </select>
  1071. <select id="querySurplusCourseFeeByClassGroupId" resultType="java.util.Map">
  1072. SELECT sr.user_id_ 'key', sr.surplus_course_fee_ 'value'
  1073. FROM student_registration sr
  1074. LEFT JOIN class_group cg ON cg.music_group_id_ = sr.music_group_id_
  1075. WHERE cg.id_ = #{classGroupId}
  1076. AND FIND_IN_SET(sr.user_id_, #{studentIds})
  1077. AND sr.music_group_status_ != 'QUIT'
  1078. </select>
  1079. <select id="queryByUserIdsAndMusicGroupId" resultMap="StudentRegistration">
  1080. SELECT sr.*, su.id_card_no_, su.organ_id_
  1081. FROM student_registration sr
  1082. LEFT JOIN sys_user su ON su.id_ = sr.user_id_
  1083. WHERE sr.music_group_id_ = #{musicGroupId}
  1084. AND FIND_IN_SET(sr.user_id_, #{studentIds})
  1085. AND sr.music_group_status_ != 'QUIT'
  1086. </select>
  1087. <select id="getStudentSubjectName" resultType="java.lang.String">
  1088. SELECT s.name_
  1089. FROM student_registration sr
  1090. LEFT JOIN subject s ON sr.actual_subject_id_ = s.id_
  1091. where sr.music_group_id_ = #{musicGroupId}
  1092. and sr.user_id_ = #{studentId}
  1093. </select>
  1094. <select id="getStudentSubjectNameByStuIds" resultType="java.util.Map">
  1095. SELECT sr.user_id_ 'key', s.name_ 'value'
  1096. FROM student_registration sr
  1097. LEFT JOIN subject s ON sr.actual_subject_id_ = s.id_
  1098. where sr.music_group_id_ = #{musicGroupId}
  1099. and sr.user_id_ IN
  1100. <foreach collection="studentIds" separator="," item="item" open="(" close=")">
  1101. #{item}
  1102. </foreach>
  1103. </select>
  1104. <select id="getStudentNormalMusicGroups" resultMap="com.ym.mec.biz.dal.dao.MusicGroupDao.MusicGroup">
  1105. SELECT DISTINCT mg.*
  1106. FROM student_registration sr
  1107. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1108. WHERE mg.status_ = 'PROGRESS'
  1109. AND sr.music_group_status_ = 'NORMAL'
  1110. AND sr.user_id_ IN
  1111. <foreach collection="studentIds" item="studentId" open="(" close=")" separator=",">
  1112. #{studentId}
  1113. </foreach>
  1114. ORDER BY mg.create_time_ DESC
  1115. </select>
  1116. <select id="getUserLastNormalMusicGroup" resultMap="com.ym.mec.biz.dal.dao.MusicGroupDao.MusicGroup">
  1117. SELECT DISTINCT mg.*
  1118. FROM student_registration sr
  1119. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1120. WHERE mg.del_flag_ = 0
  1121. AND mg.status_ = 'PROGRESS'
  1122. AND sr.music_group_status_ = 'NORMAL'
  1123. AND sr.user_id_ = #{userId}
  1124. ORDER BY sr.create_time_ DESC
  1125. LIMIT 1
  1126. </select>
  1127. <select id="getStudentNormalRegistration" resultMap="StudentRegistration">
  1128. SELECT sr.*
  1129. FROM student_registration sr
  1130. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1131. WHERE mg.status_ = 'PROGRESS'
  1132. AND mg.del_flag_ = 0
  1133. AND sr.music_group_status_ = 'NORMAL'
  1134. AND sr.user_id_ IN
  1135. <foreach collection="studentIds" item="studentId" open="(" close=")" separator=",">
  1136. #{studentId}
  1137. </foreach>
  1138. </select>
  1139. <!-- 批量删除信息 -->
  1140. <delete id="batchDelete">
  1141. DELETE
  1142. FROM student_registration WHERE id_ IN
  1143. <foreach collection="ids" item="id" open="(" close=")" separator=",">
  1144. #{id}
  1145. </foreach>
  1146. </delete>
  1147. <!-- 根据乐团编号和手机号查询注册乐团注册信息-->
  1148. <select id="getByUserIdAndMusicGroupId" resultMap="StudentRegistration">
  1149. SELECT *
  1150. FROM student_registration
  1151. WHERE music_group_id_ = #{musicGroupId}
  1152. AND user_id_ = #{userId}
  1153. </select>
  1154. <resultMap id="NoClassMusicStudentDto" type="com.ym.mec.biz.dal.dto.NoClassMusicStudentDto">
  1155. <result property="organId" column="organ_id_"/>
  1156. <result property="organName" column="organ_name_"/>
  1157. <result property="groupId" column="music_group_id_"/>
  1158. <result property="groupName" column="music_group_name_"/>
  1159. <result property="studentId" column="student_id_"/>
  1160. <result property="studentName" column="student_name_"/>
  1161. <result property="subjectId" column="subject_id_"/>
  1162. <result property="subjectName" column="subject_name_"/>
  1163. </resultMap>
  1164. <sql id="queryNoClassMusicStudentsCondition">
  1165. <where>
  1166. sr.music_group_status_ = 'NORMAL'
  1167. AND mg.status_ = 'PROGRESS'
  1168. AND cgsm.id_ IS NULL
  1169. <if test="organIds != null and organIds.size() > 0">
  1170. AND mg.organ_id_ IN
  1171. <foreach collection="organIds" item="organId" open="(" close=")" separator=",">
  1172. #{organId}
  1173. </foreach>
  1174. </if>
  1175. <if test="educationUserId != null">
  1176. AND mg.educational_teacher_id_ = #{educationUserId}
  1177. </if>
  1178. <if test="musicGroupSearch != null and musicGroupSearch != ''">
  1179. AND (sr.music_group_id_ = #{musicGroupSearch} OR mg.name_ LIKE CONCAT('%', #{musicGroupSearch}, '%'))
  1180. </if>
  1181. <if test="studentSearch != null and studentSearch != ''">
  1182. AND (sr.user_id_ = #{studentSearch} OR stu.username_ LIKE CONCAT('%', #{studentSearch}, '%'))
  1183. </if>
  1184. <if test="organId != null">
  1185. AND mg.organ_id_ = #{organId}
  1186. </if>
  1187. </where>
  1188. </sql>
  1189. <select id="queryNoClassMusicStudents" resultMap="NoClassMusicStudentDto">
  1190. SELECT mg.organ_id_,
  1191. organ.name_ organ_name_,
  1192. sr.music_group_id_,
  1193. mg.name_ music_group_name_,
  1194. sr.user_id_ student_id_,
  1195. stu.username_ student_name_,
  1196. sr.actual_subject_id_ subject_id_,
  1197. sub.name_ subject_name_
  1198. FROM student_registration sr
  1199. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1200. LEFT JOIN class_group_student_mapper cgsm ON cgsm.group_type_ = 'MUSIC'
  1201. AND cgsm.music_group_id_ = sr.music_group_id_
  1202. AND cgsm.user_id_ = sr.user_id_
  1203. AND cgsm.status_ = 'NORMAL'
  1204. LEFT JOIN sys_user stu ON stu.id_ = sr.user_id_
  1205. LEFT JOIN organization organ ON mg.organ_id_ = organ.id_
  1206. LEFT JOIN `subject` sub ON sub.id_ = sr.actual_subject_id_
  1207. <include refid="queryNoClassMusicStudentsCondition"/>
  1208. ORDER BY sr.id_
  1209. <include refid="global.limit">
  1210. </include>
  1211. </select>
  1212. <select id="countNoClassMusicStudents" resultType="int">
  1213. SELECT COUNT(sr.user_id_)
  1214. FROM student_registration sr
  1215. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1216. LEFT JOIN class_group_student_mapper cgsm ON cgsm.group_type_ = 'MUSIC'
  1217. AND cgsm.music_group_id_ = sr.music_group_id_
  1218. AND cgsm.user_id_ = sr.user_id_
  1219. AND cgsm.status_ = 'NORMAL'
  1220. LEFT JOIN sys_user stu ON stu.id_ = sr.user_id_
  1221. <include refid="queryNoClassMusicStudentsCondition"/>
  1222. </select>
  1223. <select id="getStudentClassInfo" resultType="com.ym.mec.biz.dal.dto.StudentClassInfoDto">
  1224. SELECT sr.user_id_ studentId,
  1225. sr.music_group_id_ musicGroupId,
  1226. sr.actual_subject_id_ subjectId,
  1227. cgsm.class_group_id_ classGroupId,
  1228. cgtm.user_id_ mainTeacherId,
  1229. mg.cooperation_organ_id_ cooperationOrganId
  1230. FROM student_registration sr
  1231. LEFT JOIN music_group mg ON sr.music_group_id_ = mg.id_
  1232. LEFT JOIN class_group_student_mapper cgsm
  1233. ON cgsm.group_type_ = 'MUSIC' AND cgsm.music_group_id_ = sr.music_group_id_ AND
  1234. cgsm.user_id_ = sr.user_id_
  1235. LEFT JOIN class_group cg ON cgsm.class_group_id_ = cg.id_
  1236. LEFT JOIN class_group_teacher_mapper cgtm
  1237. ON cgsm.class_group_id_ = cgtm.class_group_id_ AND cgtm.teacher_role_ = 'BISHOP'
  1238. WHERE sr.music_group_status_ = 'NORMAL'
  1239. AND mg.status_ = 'PROGRESS'
  1240. AND cgsm.status_ = 'NORMAL'
  1241. AND cg.type_ = 'NORMAL'
  1242. AND cg.del_flag_ = 0
  1243. AND cg.lock_flag_ = 0
  1244. <if test="studentIds != null and studentIds.size() > 0">
  1245. AND sr.user_id_ IN
  1246. <foreach collection="studentIds" item="studentId" open="(" close=")" separator=",">
  1247. #{studentId}
  1248. </foreach>
  1249. </if>
  1250. </select>
  1251. <select id="getPaymentStudentNum" resultType="int">
  1252. SELECT COUNT(*)
  1253. FROM student_registration
  1254. WHERE music_group_id_ = #{musicGroupId}
  1255. AND payment_status_ = 2
  1256. AND music_group_status_ = 'NORMAL'
  1257. </select>
  1258. <select id="findApplyStudent" resultMap="StudentRegistration">
  1259. SELECT *
  1260. FROM student_registration
  1261. WHERE music_group_id_ = #{musicGroupId}
  1262. AND music_group_status_ = 'APPLY'
  1263. AND user_id_ IN
  1264. <foreach collection="studentIds" item="studentId" open="(" close=")" separator=",">
  1265. #{studentId}
  1266. </foreach>
  1267. LIMIT 1
  1268. </select>
  1269. <select id="findByMusicGroupIds" resultMap="StudentRegistration">
  1270. SELECT *
  1271. FROM student_registration
  1272. WHERE music_group_id_ IN
  1273. <foreach collection="groupIds" item="groupId" open="(" close=")" separator=",">
  1274. #{groupId}
  1275. </foreach>
  1276. <if test="musicGroupStatus != null">
  1277. AND music_group_status_ = #{musicGroupStatus, typeHandler=com.ym.mec.common.dal.CustomEnumTypeHandler}
  1278. </if>
  1279. </select>
  1280. <update id="quitAllStudent">
  1281. UPDATE student_registration
  1282. SET music_group_status_ = 'QUIT',
  1283. remark_=#{remark}
  1284. WHERE music_group_id_ = #{musicGroupId}
  1285. AND music_group_status_ IN ('APPLY', 'NORMAL')
  1286. </update>
  1287. <select id="countPayingNum" resultType="map">
  1288. SELECT COUNT(DISTINCT user_id_) `value`, actual_subject_id_ `key`
  1289. FROM student_registration
  1290. WHERE music_group_id_ = #{musicGroupId}
  1291. AND paying_status_ = #{payingStatus}
  1292. AND music_group_status_ != 'QUIT'
  1293. GROUP BY actual_subject_id_
  1294. </select>
  1295. <select id="getRegisterOrPreList" resultType="com.ym.mec.biz.dal.dto.RegisterDto">
  1296. SELECT u.user_id_ userId,
  1297. su.username_ studentName,
  1298. <if test="orderByPerRegister == null">
  1299. IFNULL(spr.create_time_, '2099-12-31') perRegisterTime,
  1300. </if>
  1301. <if test="orderByPerRegister != null and orderByPerRegister == 'ASC'">
  1302. IFNULL(spr.create_time_, '2099-12-31') perRegisterTime,
  1303. </if>
  1304. <if test="orderByPerRegister != null and orderByPerRegister == 'DESC'">
  1305. IFNULL(spr.create_time_, '1990-12-31') perRegisterTime,
  1306. </if>
  1307. <if test="orderByPayTime == null">
  1308. IFNULL(o.payTime, '2099-12-31') payTime,
  1309. </if>
  1310. <if test="orderByPayTime != null and orderByPayTime == 'ASC'">
  1311. IFNULL(o.payTime, '2099-12-31') payTime,
  1312. </if>
  1313. <if test="orderByPayTime != null and orderByPayTime == 'DESC'">
  1314. IFNULL(o.payTime, '1990-12-31') payTime,
  1315. </if>
  1316. IFNULL(s2.name_, s1.name_) actualSubjectName
  1317. FROM (SELECT user_id_
  1318. FROM student_pre_registration
  1319. WHERE music_group_id_ = #{musicGroupId}
  1320. UNION
  1321. SELECT user_id_
  1322. FROM student_registration
  1323. where music_group_id_ = #{musicGroupId}
  1324. ) u
  1325. LEFT JOIN sys_user su ON su.id_ = u.user_id_
  1326. LEFT JOIN student_pre_registration spr
  1327. ON spr.user_id_ = u.user_id_ AND spr.music_group_id_ = #{musicGroupId}
  1328. LEFT JOIN student_registration sr
  1329. ON sr.user_id_ = u.user_id_ AND sr.music_group_id_ = #{musicGroupId}
  1330. LEFT JOIN subject s1 ON spr.subject_first_ = s1.id_
  1331. LEFT JOIN subject s2 ON sr.actual_subject_id_ = s2.id_
  1332. LEFT JOIN (
  1333. SELECT spo.user_id_, MAX(spo.pay_time_) payTime
  1334. FROM student_payment_order spo
  1335. WHERE spo.music_group_id_ = #{musicGroupId}
  1336. AND spo.status_ = 'SUCCESS'
  1337. AND type_ = 'APPLY'
  1338. GROUP BY spo.user_id_
  1339. ) o ON o.user_id_ = u.user_id_
  1340. <where>
  1341. <if test="userIds != null">
  1342. AND u.user_id_ IN
  1343. <foreach collection="userIds" item="userId" open="(" close=")" separator=",">
  1344. #{userId}
  1345. </foreach>
  1346. </if>
  1347. <if test="subjectId">
  1348. AND (sr.actual_subject_id_ = #{subjectId} OR spr.subject_first_ = #{subjectId})
  1349. </if>
  1350. </where>
  1351. <if test="orderByPerRegister != null and orderByPayTime == null">
  1352. ORDER BY perRegisterTime ${orderByPerRegister},u.user_id_ ASC
  1353. </if>
  1354. <if test="orderByPerRegister != null and orderByPayTime != null">
  1355. ORDER BY perRegisterTime ${orderByPerRegister}, payTime ${orderByPayTime}, u.user_id_ ASC
  1356. </if>
  1357. <if test="orderByPerRegister == null and orderByPayTime != null">
  1358. ORDER BY payTime ${orderByPayTime}, u.user_id_ ASC
  1359. </if>
  1360. <if test="orderByPerRegister == null and orderByPayTime == null">
  1361. ORDER BY perRegisterTime ASC, u.user_id_ ASC
  1362. </if>
  1363. <include refid="global.limit"/>
  1364. </select>
  1365. <select id="getRegisterOrPreCount" resultType="int">
  1366. SELECT COUNT(*)
  1367. FROM (SELECT user_id_
  1368. FROM student_pre_registration
  1369. WHERE music_group_id_ = #{musicGroupId}
  1370. UNION
  1371. SELECT user_id_
  1372. FROM student_registration
  1373. where music_group_id_ = #{musicGroupId}
  1374. ) u
  1375. LEFT JOIN sys_user su ON su.id_ = u.user_id_
  1376. LEFT JOIN student_pre_registration spr
  1377. ON spr.user_id_ = u.user_id_ AND spr.music_group_id_ = #{musicGroupId}
  1378. LEFT JOIN student_registration sr
  1379. ON sr.user_id_ = u.user_id_ AND sr.music_group_id_ = #{musicGroupId}
  1380. LEFT JOIN subject s1 ON spr.subject_first_ = s1.id_
  1381. LEFT JOIN subject s2 ON sr.actual_subject_id_ = s2.id_
  1382. <where>
  1383. <if test="userIds != null">
  1384. AND u.user_id_ IN
  1385. <foreach collection="userIds" item="userId" open="(" close=")" separator=",">
  1386. #{userId}
  1387. </foreach>
  1388. </if>
  1389. <if test="subjectId">
  1390. AND (sr.actual_subject_id_ = #{subjectId} OR spr.subject_first_ = #{subjectId})
  1391. </if>
  1392. </where>
  1393. </select>
  1394. <select id="getRegisterOrPreMinTime" resultType="com.ym.mec.biz.dal.dto.RegisterDto">
  1395. SELECT MIN(o.payTime) minPayTime,MIN(spr.create_time_) minPerRegisterTime
  1396. FROM (SELECT user_id_
  1397. FROM student_pre_registration
  1398. WHERE music_group_id_ = #{musicGroupId}
  1399. UNION
  1400. SELECT user_id_
  1401. FROM student_registration
  1402. where music_group_id_ = #{musicGroupId}
  1403. ) u
  1404. LEFT JOIN student_pre_registration spr
  1405. ON spr.user_id_ = u.user_id_ AND spr.music_group_id_ = #{musicGroupId}
  1406. LEFT JOIN (
  1407. SELECT spo.user_id_, MAX(spo.pay_time_) payTime
  1408. FROM student_payment_order spo
  1409. WHERE spo.music_group_id_ = #{musicGroupId}
  1410. AND spo.status_ = 'SUCCESS'
  1411. AND spo.type_ = 'APPLY'
  1412. GROUP BY spo.user_id_
  1413. ) o ON o.user_id_ = u.user_id_
  1414. </select>
  1415. <select id="getRegisterNum" resultType="int">
  1416. SELECT COUNT(*) FROM student_registration WHERE music_group_id_ = #{musicGroupId} AND music_group_status_ != 'QUIT'
  1417. </select>
  1418. <select id="getFirstPayNum" resultType="int">
  1419. SELECT COUNT(*)
  1420. FROM student_registration sr
  1421. LEFT JOIN (
  1422. SELECT spo.user_id_, MAX(spo.pay_time_) payTime
  1423. FROM student_payment_order spo
  1424. WHERE spo.music_group_id_ = #{musicGroupId}
  1425. AND spo.status_ = 'SUCCESS'
  1426. AND spo.type_ = 'APPLY'
  1427. GROUP BY spo.user_id_
  1428. ) o ON o.user_id_ = sr.user_id_
  1429. WHERE sr.music_group_id_ = #{musicGroupId} AND sr.payment_status_=2
  1430. <if test="startTime != null">
  1431. AND o.payTime >= #{startTime}
  1432. </if>
  1433. <if test="endTime != null">
  1434. <![CDATA[ AND o.payTime <= #{endTime}]]>
  1435. </if>
  1436. AND sr.music_group_status_ != 'QUIT'
  1437. </select>
  1438. <select id="getNotClassName" resultType="java.lang.String">
  1439. SELECT GROUP_CONCAT(DISTINCT su.username_) FROM student_registration sr
  1440. LEFT JOIN sys_user su ON su.id_ = sr.user_id_
  1441. WHERE sr.music_group_id_ = #{musicGroupId} AND sr.music_group_status_ = 'NORMAL'
  1442. AND sr.user_id_ NOT IN (SELECT DISTINCT cgsm.user_id_ FROM class_group_student_mapper cgsm
  1443. LEFT JOIN class_group cg ON cg.id_ = cgsm.class_group_id_
  1444. WHERE cgsm.music_group_id_ = #{musicGroupId} AND cgsm.group_type_ = 'MUSIC'
  1445. AND cgsm.status_ != 'QUIT' AND cg.del_flag_ = 0 AND cg.type_ IN ('NORMAL','MIX'))
  1446. </select>
  1447. <select id="checkHasMemberGroup" resultType="java.lang.Boolean">
  1448. SELECT COUNT(sr.id_) > 0 FROM student_registration sr
  1449. LEFT JOIN music_group mg ON mg.id_ = sr.music_group_id_
  1450. WHERE sr.music_group_id_ != #{musicGroupId} AND sr.music_group_status_ != 'QUIT' AND sr.user_id_ = #{userId} AND mg.course_view_type_ = 1
  1451. </select>
  1452. <!-- 获取报名相关数据 -->
  1453. <select id="getRegisters" resultType="com.ym.mec.biz.dal.dto.MusicGroupRegAndMoneyDto">
  1454. SELECT music_group_id_ musicGroupId, COUNT(*) regNum,SUM(IF(payment_status_ = '2',1,0)) payNum,
  1455. SUM(IF(paying_status_='2',1,0)) checkNum,SUM(IF((music_group_status_= 'NORMAL' and has_cloud_teacher_=1),1,0)) buyCloudTeacherNum
  1456. FROM student_registration
  1457. WHERE music_group_id_ IN
  1458. <foreach collection="musicGroupIds" item="musicGroupId" open="(" close=")" separator=",">
  1459. #{musicGroupId}
  1460. </foreach>
  1461. AND music_group_status_ != 'QUIT'
  1462. GROUP BY music_group_id_
  1463. </select>
  1464. <select id="countPayAndCheckNum" resultType="int">
  1465. SELECT COUNT(*)
  1466. FROM student_registration
  1467. WHERE music_group_id_ = #{musicGroupId}
  1468. AND payment_status_ =2
  1469. AND paying_status_ = 2
  1470. AND music_group_status_ = 'NORMAL'
  1471. </select>
  1472. <select id="queryMemberEndAutoQuitMusic" resultMap="StudentRegistration">
  1473. SELECT sr.music_group_id_,sr.user_id_ FROM student_registration sr
  1474. LEFT JOIN music_group mg ON mg.id_ = sr.music_group_id_
  1475. LEFT JOIN cloud_teacher_order cto ON cto.student_id_ = sr.user_id_ AND cto.status_ IN (1,2)
  1476. WHERE sr.music_group_status_ = 'NORMAL' AND mg.course_view_type_ = 1
  1477. AND mg.status_ = 'PROGRESS'
  1478. <if test="educationUserId != null">
  1479. AND mg.educational_teacher_id_ = #{educationUserId}
  1480. </if>
  1481. <if test="organIds != null and organIds != ''">
  1482. AND FIND_IN_SET(mg.organ_id_,#{organIds})
  1483. </if>
  1484. GROUP BY sr.user_id_ HAVING (MAX(cto.id_) IS NULL OR MIN(cto.status_) > 1)
  1485. <if test="memberEndAutoQuitMusic != null">
  1486. AND DATEDIFF(MAX(cto.end_time_),NOW()) &lt;= #{memberEndAutoQuitMusic} AND DATEDIFF(MAX(cto.end_time_),NOW()) >= 0
  1487. </if>
  1488. <if test="memberEndAutoQuitMusic == null">
  1489. AND (MAX(cto.id_) IS NULL OR DATEDIFF(MAX(cto.end_time_),NOW()) &lt; 0)
  1490. </if>
  1491. </select>
  1492. </mapper>