HomeworkMapper.xml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412
  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. <mapper namespace="com.ssj.service.mapper.HomeworkMapper">
  4. <update id="deleteWrongQuestionKnowledgeCount">
  5. update scon_knowledge_wrong_question_count
  6. set mastered = 1
  7. where homework_id = #{homeworkId}
  8. and how_detail_id = #{knowHowDetailId}
  9. and knowledge_version = #{knowledgeVersion}
  10. </update>
  11. <update id="updateNeedUpdateWrongQuestionKnowledgeCount">
  12. update scon_homework set scon_homework.need_update_wrong_question_knowledge_count = #{newNeedUpdateWrongQuestionKnowledgeCount}
  13. where id in
  14. <foreach collection="homeworkIdSet" open="(" item="homeworkId" separator="," close=")">
  15. #{homeworkId}
  16. </foreach>
  17. </update>
  18. <delete id="deleteWrongQuestionKnowledgeCountByHomeworkId">
  19. delete kwqc from scon_knowledge_wrong_question_count kwqc
  20. where kwqc.homework_id = #{homeworkId}
  21. </delete>
  22. <delete id="deleteWrongQuestionKnowledgeCountWhichNeedUpdate">
  23. delete kwqc
  24. from scon_knowledge_wrong_question_count kwqc, scon_homework h
  25. where kwqc.homework_id = h.id and h.need_update_wrong_question_knowledge_count = 1
  26. </delete>
  27. <select id="findMinCreateTime" resultType="java.util.Date">
  28. select min(create_time) from scon_homework
  29. </select>
  30. <select id="countHomeworkData" resultType="com.ssj.bean.sys.homework.domain.HomeworkCount">
  31. select scon_homework.id homework_id,
  32. scon_homework.vip_id,
  33. scon_homework.grade,
  34. scon_homework.subject,
  35. scon_homework.used_time,
  36. scon_homework.create_time homework_time,
  37. sum(if(scon_homework_how_details.id is not null and scon_homework_how_details.wrong_question_id is null,
  38. ifnull(scon_homework_how_details.detail_count, 0), 0)) /
  39. if(count(distinct kmt_homework_wrong_question.id) = 0, 1, count(distinct kmt_homework_wrong_question.id)) +
  40. count(distinct if(kmt_homework_wrong_question.type = 1, kmt_homework_wrong_question.id, null)) wrong_count,
  41. sum(if(scon_homework_how_details.id is not null and scon_homework_how_details.wrong_question_id is null,
  42. ifnull(scon_homework_how_details.total_count, 1), 0)) /
  43. if(count(distinct kmt_homework_wrong_question.id) = 0, 1, count(distinct kmt_homework_wrong_question.id)) +
  44. count(distinct kmt_homework_wrong_question.id) total_count
  45. from scon_homework
  46. left join scon_homework_how_details on scon_homework_how_details.homework_id = scon_homework.id
  47. left join kmt_homework_wrong_question on kmt_homework_wrong_question.homework_id = scon_homework.id and
  48. kmt_homework_wrong_question.is_delete = 0
  49. where scon_homework.create_time between #{beginDateTimeStr} and #{endDateTimeStr}
  50. group by scon_homework.create_time, scon_homework.id
  51. </select>
  52. <select id="countHomeworkDataByHomeworkId" resultType="com.ssj.bean.sys.homework.domain.HomeworkCount">
  53. select scon_homework.id homework_id,
  54. scon_homework.vip_id,
  55. scon_homework.grade,
  56. scon_homework.subject,
  57. scon_homework.used_time,
  58. scon_homework.create_time homework_time,
  59. sum(if(scon_homework_how_details.id is not null and scon_homework_how_details.wrong_question_id is null,
  60. ifnull(scon_homework_how_details.detail_count, 0), 0)) /
  61. if(count(distinct kmt_homework_wrong_question.id) = 0, 1, count(distinct kmt_homework_wrong_question.id)) +
  62. count(distinct if(kmt_homework_wrong_question.type = 1, kmt_homework_wrong_question.id, null)) wrong_count,
  63. sum(if(scon_homework_how_details.id is not null and scon_homework_how_details.wrong_question_id is null,
  64. ifnull(scon_homework_how_details.total_count, 1), 0)) /
  65. if(count(distinct kmt_homework_wrong_question.id) = 0, 1, count(distinct kmt_homework_wrong_question.id)) +
  66. count(distinct kmt_homework_wrong_question.id) total_count
  67. from scon_homework
  68. left join scon_homework_how_details on scon_homework_how_details.homework_id = scon_homework.id
  69. left join kmt_homework_wrong_question on kmt_homework_wrong_question.homework_id = scon_homework.id and
  70. kmt_homework_wrong_question.is_delete = 0
  71. where scon_homework.id = #{homeworkId}
  72. group by scon_homework.id
  73. </select>
  74. <select id="findHomeworkAccuracyRateList" resultType="com.ssj.service.conch.parents.dto.HomeworkAccuracyRateDto">
  75. select scon_homework_count.homework_time date,
  76. scon_homework_count.accuracy_rate rate,
  77. scon_homework_count.wrong_count,
  78. scon_homework_count.total_count
  79. from scon_homework_count
  80. where scon_homework_count.vip_id = #{vipId}
  81. and scon_homework_count.homework_time > #{beginTimeStr}
  82. and #{endTimeStr} > scon_homework_count.homework_time
  83. </select>
  84. <!--查询近七天的作业记录-->
  85. <select id="findConchHomeworkRecord" resultType="com.ssj.bean.conch.conch.domain.HomeworkRecord">
  86. select homework_id, subject, date(create_time) date, sum(if(is_feedback = 0 and is_mark in (0, 2), 1, 0)) not_corrected_count,
  87. if(count(if(is_feedback = 1 or is_mark = 1 or is_mark = 3, 1, 0)) = sum(if(is_feedback = 1 or is_mark = 1 or is_mark = 3, 1, 0)), 5, 0) type,
  88. min(file_key) homework_picture_url
  89. from scon_homework_picture where vip_id=#{vipId}
  90. and create_time between #{beginTime} and #{endTime}
  91. and is_delete = 0
  92. group by homework_id, subject, date
  93. order by date desc
  94. </select>
  95. <!--查询某个作业记录-->
  96. <select id="findOneConchHomeworkRecord" resultType="com.ssj.bean.conch.conch.domain.HomeworkRecord">
  97. select homework_id, subject, date(create_time) date,
  98. if(count(if(is_feedback = 1 or is_mark = 1 or is_mark = 3, 1, 0)) = sum(if(is_feedback = 1 or is_mark = 1 or is_mark = 3, 1, 0)), 5, 0) type,
  99. min(file_key) homework_picture_url
  100. from scon_homework_picture where homework_id=#{homeworkId}
  101. group by homework_id, subject, date
  102. </select>
  103. <!--查询近两天待处理记录-->
  104. <select id="findConchHandleTask" resultType="com.ssj.bean.conch.conch.domain.HomeworkRecord">
  105. select id, file_key homework_picture_url, subject, homework_id, date(create_time) date, is_mark type from scon_homework_picture
  106. where create_time between #{beginTime} and #{endTime} and vip_id=#{vipId} and is_mark in (1, 3)
  107. </select>
  108. <select id="countMonthlyHomeworkData" resultType="com.ssj.bean.sys.homework.domain.HomeworkCount">
  109. select vip_id,
  110. homework_id,
  111. grade,
  112. ifnull(sum(used_time), 0) used_time,
  113. count(distinct date_format(homework_time, '%Y-%m-%d')) homework_days,
  114. ifnull(sum(wrong_count), 0) wrong_count,
  115. ifnull(sum(total_count), 0) total_count
  116. from scon_homework_count
  117. where data_type = 1
  118. and homework_time > #{beginDateTimeStr}
  119. and #{endDateTimeStr} > homework_time
  120. group by vip_id, grade
  121. </select>
  122. <select id="findByVipIdAndMonth" resultType="com.ssj.bean.sys.homework.domain.HomeworkCount">
  123. select * from scon_homework_count where vip_id = #{vipId} and grade = #{grade} and data_type = 2 and homework_month = #{month}
  124. </select>
  125. <select id="findMinHomeworkMonth" resultType="java.lang.String">
  126. select homework_month from scon_homework_count where data_type = 1 order by homework_time limit 1
  127. </select>
  128. <select id="findVipIdNeedPushWeeklyNotify" resultType="java.lang.String">
  129. select vip_id
  130. from scon_homework_count
  131. where homework_time > #{beginDateTimeStr}
  132. and #{endDateTimeStr} > homework_time
  133. and data_type = 1
  134. group by vip_id
  135. </select>
  136. <select id="findVipIdNeedPushMonthlyNotify" resultType="java.lang.String">
  137. select vip_id from scon_homework_count where data_type = 2 and homework_month = #{month}
  138. </select>
  139. <select id="findByVipId" resultType="com.ssj.service.conch.conch.dto.RankDTO">
  140. select user_name, img_url, ranking_num, rowno as `index`, vip_id
  141. from (select a.child_name as user_name,
  142. a.img_url,
  143. a.vip_id,
  144. a.ranking_num,
  145. (@rowno := @rowno + 1) as rowno
  146. from (select tb_lib_vip.child_name,
  147. tb_lib_vip.img_url,
  148. tb_lib_vip.id vip_id,
  149. scon_homework_ranking.ranking_num,
  150. scon_homework_ranking.update_time
  151. from scon_homework_ranking,
  152. tb_lib_vip
  153. where scon_homework_ranking.vip_id = tb_lib_vip.id) as a,
  154. (select @rowno := 0) as row
  155. order by a.ranking_num desc, a.update_time desc) as temp
  156. where temp.vip_id = #{vipId}
  157. </select>
  158. <!--查询批改老师作业列表的质检中状态-->
  159. <select id="findHomeworkCheckStatus" resultType="com.ssj.bean.conch.conch.dto.HomeworkCheckStatusDto">
  160. select hpc.homework_id, count(hpc.check_start_time) count_check_start_time, count(hpc.check_end_time) count_check_end_time, count(1) total_count
  161. from scon_homework_picture_correct hpc, scon_homework_picture hp where hpc.homework_picture_id=hp.id
  162. <if test="type == 8">
  163. and hpc.type=8 and hp.teacher_id=#{teacherId}
  164. </if>
  165. <if test="type == 13">
  166. and hpc.type=13 and hp.know_teacher_id=#{teacherId}
  167. </if>
  168. and hp.homework_id in
  169. <foreach collection="homeworkIds" item="id" index="index" open="(" close=")" separator=",">
  170. #{id}
  171. </foreach>
  172. group by hpc.homework_id
  173. </select>
  174. <select id="countWeeklyHomeworkData" resultType="com.ssj.bean.sys.homework.domain.StudentWeeklyReport">
  175. select vip_id, subject, sum(wrong_count) wrong_count, sum(total_count) total_count
  176. from scon_homework_count
  177. where data_type = 1
  178. and homework_time > #{beginDateTime}
  179. and #{endDateTime} > homework_time
  180. group by vip_id, subject
  181. </select>
  182. <select id="findWeeklyReportHistory" resultType="com.ssj.service.conch.parents.v2.dto.StudentWeeklyReportDTO">
  183. select vip_id,
  184. group_concat(subject) subject_str,
  185. group_concat(accuracy_rate) accuracy_rate_str,
  186. sum(total_knowledge_num) total_knowledge_num,
  187. sum(master_well_knowledge_num) master_well_knowledge_num,
  188. sum(master_infirmly_knowledge_num) master_infirmly_knowledge_num,
  189. sum(not_mastered_knowledge_num) not_mastered_knowledge_num,
  190. begin_date begin_time,
  191. end_date end_time
  192. from scon_student_weekly_report
  193. where vip_id = #{vipId}
  194. group by vip_id, begin_date
  195. order by begin_date desc
  196. limit 30
  197. </select>
  198. <select id="findMonthlyReportHistory" resultType="com.ssj.service.conch.parents.v2.dto.MonthlyReportDTO">
  199. select accuracy_rate learning_score,
  200. homework_month,
  201. transcended_student_proportion,
  202. increased_score
  203. from scon_homework_count
  204. where data_type = 2
  205. and vip_id = #{vipId}
  206. order by homework_month desc
  207. limit 12
  208. </select>
  209. <select id="countWrongQuestion" resultType="java.lang.Integer">
  210. select count(*)
  211. from scon_homework_how_details, scon_homework
  212. where scon_homework_how_details.homework_id = scon_homework.id
  213. and scon_homework_how_details.is_wrong_ques_delete = 0
  214. <if test="type == 2">
  215. and scon_homework_how_details.wrong_question_id is not null
  216. </if>
  217. <if test="type != 2">
  218. and scon_homework_how_details.detail_count > 0
  219. </if>
  220. and scon_homework_how_details.how_detail_id in
  221. <foreach collection="knowledgeIdList" open="(" item="knowledgeId" separator="," close=")">
  222. #{knowledgeId}
  223. </foreach>
  224. and knowledge_version = #{version}
  225. and scon_homework.vip_id = #{vipId}
  226. <if test="beginDateTimeStr != ''">
  227. and scon_homework.create_time > #{beginDateTimeStr}
  228. </if>
  229. <if test="endDateTimeStr != ''">
  230. and #{endDateTimeStr} > scon_homework.create_time
  231. </if>
  232. </select>
  233. <select id="findWrongQuestionId" resultType="java.lang.String">
  234. <foreach collection="knowHowDetailList" open="" item="knowHowDetail" separator=" union " close="">
  235. select distinct kmt_homework_wrong_question.question_id
  236. from scon_homework,
  237. scon_homework_how_details,
  238. kmt_homework_wrong_question
  239. where scon_homework.id = scon_homework_how_details.homework_id
  240. and scon_homework_how_details.wrong_question_id = kmt_homework_wrong_question.id
  241. and kmt_homework_wrong_question.is_delete = 0
  242. and scon_homework.vip_id = #{vipId}
  243. <if test="beginDateTimeStr != ''">
  244. and scon_homework.create_time > #{beginDateTimeStr}
  245. </if>
  246. <if test="endDateTimeStr != ''">
  247. and #{endDateTimeStr} > scon_homework.create_time
  248. </if>
  249. and scon_homework_how_details.how_detail_id = #{knowHowDetail.knowHowDetailId}
  250. and scon_homework_how_details.knowledge_version = #{knowHowDetail.knowledgeVersion}
  251. </foreach>
  252. </select>
  253. <select id="findWeeklyReportByVipIdAndSubjectAndBeginDate" resultType="com.ssj.bean.sys.homework.domain.StudentWeeklyReport">
  254. select *
  255. from scon_student_weekly_report
  256. where vip_id = #{vipId}
  257. and subject = #{subject}
  258. and begin_date = #{beginDate}
  259. </select>
  260. <select id="findWrongQuestionHowDetailKdId" resultType="java.lang.String">
  261. select kmt_exercise_question_know.how_details_kd_id
  262. from kmt_exercise_question_know
  263. inner join (select kmt_homework_wrong_question.question_id
  264. from scon_homework,
  265. scon_homework_how_details,
  266. kmt_homework_wrong_question
  267. where scon_homework.id = scon_homework_how_details.homework_id
  268. and scon_homework_how_details.wrong_question_id = kmt_homework_wrong_question.id
  269. and scon_homework.vip_id = #{vipId}
  270. and scon_homework.create_time between #{beginTime} and #{endTime}
  271. and scon_homework_how_details.how_detail_id in
  272. <foreach collection="knowHowDetailIdSet" open="(" item="knowHowDetailId" separator="," close=")">
  273. #{knowHowDetailId}
  274. </foreach>
  275. ) temp
  276. on kmt_exercise_question_know.question_id = temp.question_id
  277. and how_details_kd_id is not null
  278. </select>
  279. <select id="findMonthlyReport" resultType="com.ssj.bean.sys.homework.domain.HomeworkCount">
  280. select * from scon_homework_count where data_type = 2
  281. </select>
  282. <select id="countWrongQuestionGroupByKnowledge" resultType="com.ssj.bean.sys.homework.domain.KnowledgeWrongQuestionCount">
  283. select homework.id homework_id,
  284. homework.vip_id,
  285. homework.subject,
  286. homework.create_time homework_time,
  287. scon_homework_how_details.how_detail_id,
  288. scon_homework_how_details.knowledge_version,
  289. scon_homework_how_details.grade,
  290. scon_homework_how_details.semester,
  291. zyb_know_how_details_sort.module,
  292. zyb_know_how_details_sort.two_module,
  293. zyb_know_how_details_sort.alias knowledge_name,
  294. count(distinct scon_homework_how_details.homework_picture_id) wrong_count,
  295. count(distinct scon_homework_how_details.wrong_question_id) question_status,
  296. scon_homework_how_details.is_wrong_ques_delete mastered
  297. from (select id, vip_id, subject, create_time
  298. from scon_homework
  299. where
  300. <choose>
  301. <when test="homeworkId != null and homeworkId != ''">
  302. id = #{homeworkId}
  303. limit 1
  304. </when>
  305. <otherwise>
  306. need_update_wrong_question_knowledge_count = 1
  307. limit #{pageSize}
  308. </otherwise>
  309. </choose>
  310. ) homework
  311. join scon_homework_how_details on homework.id = scon_homework_how_details.homework_id
  312. join zyb_know_how_details_sort
  313. on scon_homework_how_details.how_detail_id = zyb_know_how_details_sort.how_details_id
  314. and scon_homework_how_details.grade = zyb_know_how_details_sort.grade
  315. and scon_homework_how_details.semester = zyb_know_how_details_sort.semester
  316. and scon_homework_how_details.knowledge_version = zyb_know_how_details_sort.type
  317. and zyb_know_how_details_sort.stat = 2
  318. and zyb_know_how_details_sort.lib_id = 'SSJ'
  319. where scon_homework_how_details.detail_count > 0
  320. group by homework.vip_id, scon_homework_how_details.how_detail_id, scon_homework_how_details.knowledge_version,
  321. scon_homework_how_details.grade,
  322. scon_homework_how_details.semester
  323. </select>
  324. <!--单科批改详情作业图片列表-->
  325. <select id="findHomeworkCorrectDetailByHomeworkId" resultType="com.ssj.bean.sys.homework.domain.HomeworkPicture">
  326. select id, file_key, is_feedback, is_mark, teacher_id, corrected_picture_url, is_composition,homework_comment, create_time from scon_homework_picture
  327. where homework_id=#{homeworkId} AND is_delete=0 ORDER BY create_time ASC
  328. </select>
  329. <select id="countOthersAndAccuracyRateLessThan" resultType="java.util.Map">
  330. select sum(if(#{accuracyRate} > others.accuracy_rate, 1, 0)) accuracyRateLessThanCount, count(*) othersCount
  331. from scon_homework_count others
  332. where others.homework_month = #{targetMonthStr}
  333. and others.data_type = 2
  334. and others.vip_id &lt;> #{vipId}
  335. and others.grade = #{grade}
  336. </select>
  337. <select id="findMonthlyReportByMonth" resultType="com.ssj.bean.sys.homework.domain.HomeworkCount">
  338. select * from scon_homework_count where data_type = 2
  339. <if test="targetMonthStr != null and targetMonthStr.length > 0">
  340. and homework_month = #{targetMonthStr}
  341. </if>
  342. </select>
  343. <select id="findWrongQuestionKnowledgeCount" resultType="com.ssj.bean.sys.homework.domain.KnowledgeWrongQuestionCount">
  344. select * from scon_knowledge_wrong_question_count where 1 > question_status
  345. </select>
  346. <select id="findHomeworkInfoYesterday" resultType="java.util.Map">
  347. select homework.vip_id, homework.subject, homework.grade
  348. from (select vip_id, subject, grade
  349. from scon_homework
  350. where scon_homework.create_time > #{yesterdayDate}) homework
  351. join tb_lib_vip on homework.vip_id = tb_lib_vip.id and tb_lib_vip.stat = '1'
  352. </select>
  353. <!--查询没有作业采集到的知识点-->
  354. <select id="findNoLearnKnowledgeList" resultType="java.lang.String">
  355. select detail.how_details_id from scon_homework_how_details t1
  356. left join scon_homework h on t1.homework_id=h.id
  357. right join zyb_know_how_details_sort detail
  358. on t1.how_detail_id=detail.how_details_id and t1.grade=detail.grade
  359. and t1.semester=2 and t1.knowledge_version=detail.type and h.vip_id=#{vipId}
  360. where detail.stat=2 and detail.grade=#{grade} and detail.course_name=#{subject} and detail.semester=#{semester}
  361. and detail.type=#{versionType} and t1.id is null
  362. </select>
  363. <select id="findStudentTermTrainDetailIdByVipId" resultType="com.ssj.bean.conch.conch.domain.SconStudentTermtainData">
  364. select * from scon_student_termtain_data where vip_id=#{vipId} and type=#{type} and storage_data_type = 0
  365. </select>
  366. <select id="findWrongQuestionIdHomeworkPictureId" resultType="java.util.Map">
  367. select homework_picture_id, question_id
  368. from kmt_homework_wrong_question
  369. where homework_picture_id in
  370. <foreach collection="homeworkPictureIdList" open="(" item="homeworkPictureId" separator="," close=")">
  371. #{homeworkPictureId}
  372. </foreach>
  373. and kmt_homework_wrong_question.type = 1
  374. and kmt_homework_wrong_question.is_delete = 0
  375. and kmt_homework_wrong_question.is_wrong_ques_delete = 0
  376. </select>
  377. </mapper>