FsUserCourseCountMapper.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="com.fs.store.mapper.FsUserCourseCountMapper">
  6. <resultMap type="FsUserCourseCount" id="FsUserCourseCountResult">
  7. <result property="id" column="id" />
  8. <result property="userId" column="user_id" />
  9. <result property="watchCourseCount" column="watch_course_count" />
  10. <result property="missCourseCount" column="miss_course_count" />
  11. <result property="missCourseStatus" column="miss_course_status" />
  12. <result property="missCourseDays" column="miss_course_days" />
  13. <result property="courseIds" column="course_idss" />
  14. <result property="partCourseCount" column="part_course_count" />
  15. <result property="lastWatchDate" column="last_watch_date" />
  16. <result property="status" column="status" />
  17. <result property="stopWatchDays" column="stop_watch_days" />
  18. <result property="createTime" column="create_time" />
  19. <result property="updateTime" column="update_time" />
  20. <result property="createBy" column="create_by" />
  21. <result property="updateBy" column="update_by" />
  22. <result property="completeWatchDate" column="complete_watch_date" />
  23. <result property="completeWatchCount" column="complete_watch_count" />
  24. <result property="watchTimes" column="watch_times" />
  25. <result property="createDate" column="create_date" />
  26. </resultMap>
  27. <sql id="selectFsUserCourseCountVo">
  28. select id, user_id, watch_course_count, miss_course_count, miss_course_status, miss_course_days, course_ids, part_course_count, last_watch_date, status, stop_watch_days, create_time, update_time, create_by, update_by, complete_watch_date, complete_watch_count, watch_times, create_date from fs_user_course_count
  29. </sql>
  30. <select id="selectFsUserCourseCountList" parameterType="FsUserCourseCount" resultMap="FsUserCourseCountResult">
  31. <include refid="selectFsUserCourseCountVo"/>
  32. <where>
  33. <if test="userId != null "> and user_id = #{userId}</if>
  34. <if test="watchCourseCount != null "> and watch_course_count = #{watchCourseCount}</if>
  35. <if test="missCourseCount != null "> and miss_course_count = #{missCourseCount}</if>
  36. <if test="missCourseStatus != null "> and miss_course_status = #{missCourseStatus}</if>
  37. <if test="missCourseDays != null "> and miss_course_days = #{missCourseDays}</if>
  38. <if test="courseIds != null "> and course_ids = #{courseIds}</if>
  39. <if test="partCourseCount != null and partCourseCount != ''"> and part_course_count = #{partCourseCount}</if>
  40. <if test="lastWatchDate != null "> and last_watch_date = #{lastWatchDate}</if>
  41. <if test="status != null "> and status = #{status}</if>
  42. <if test="stopWatchDays != null "> and stop_watch_days = #{stopWatchDays}</if>
  43. <if test="completeWatchDate != null "> and complete_watch_date = #{completeWatchDate}</if>
  44. <if test="completeWatchCount != null "> and complete_watch_count = #{completeWatchCount}</if>
  45. <if test="watchTimes != null "> and watch_times = #{watchTimes}</if>
  46. <if test="createDate != null "> and create_date = #{createDate}</if>
  47. </where>
  48. </select>
  49. <select id="selectFsUserCourseCountById" parameterType="Long" resultMap="FsUserCourseCountResult">
  50. <include refid="selectFsUserCourseCountVo"/>
  51. where id = #{id}
  52. </select>
  53. <select id="findByUserId" resultType="com.fs.store.domain.FsUserCourseCount">
  54. select * from fs_user_course_count where user_id = ${userId} limit 1
  55. </select>
  56. <insert id="insertFsUserCourseCount" parameterType="FsUserCourseCount">
  57. insert into fs_user_course_count
  58. <trim prefix="(" suffix=")" suffixOverrides=",">
  59. <if test="id != null">id,</if>
  60. <if test="userId != null">user_id,</if>
  61. <if test="watchCourseCount != null">watch_course_count,</if>
  62. <if test="missCourseCount != null">miss_course_count,</if>
  63. <if test="missCourseStatus != null">miss_course_status,</if>
  64. <if test="missCourseDays != null">miss_course_days,</if>
  65. <if test="courseIds != null">course_ids,</if>
  66. <if test="partCourseCount != null">part_course_count,</if>
  67. <if test="lastWatchDate != null">last_watch_date,</if>
  68. <if test="status != null">status,</if>
  69. <if test="stopWatchDays != null">stop_watch_days,</if>
  70. <if test="createTime != null">create_time,</if>
  71. <if test="updateTime != null">update_time,</if>
  72. <if test="createBy != null">create_by,</if>
  73. <if test="updateBy != null">update_by,</if>
  74. <if test="completeWatchDate != null">complete_watch_date,</if>
  75. <if test="completeWatchCount != null">complete_watch_count,</if>
  76. <if test="watchTimes != null">watch_times,</if>
  77. <if test="createDate != null">create_date,</if>
  78. </trim>
  79. <trim prefix="values (" suffix=")" suffixOverrides=",">
  80. <if test="id != null">#{id},</if>
  81. <if test="userId != null">#{userId},</if>
  82. <if test="watchCourseCount != null">#{watchCourseCount},</if>
  83. <if test="missCourseCount != null">#{missCourseCount},</if>
  84. <if test="missCourseStatus != null">#{missCourseStatus},</if>
  85. <if test="missCourseDays != null">#{missCourseDays},</if>
  86. <if test="courseIds != null">#{courseIds},</if>
  87. <if test="partCourseCount != null">#{partCourseCount},</if>
  88. <if test="lastWatchDate != null">#{lastWatchDate},</if>
  89. <if test="status != null">#{status},</if>
  90. <if test="stopWatchDays != null">#{stopWatchDays},</if>
  91. <if test="createTime != null">#{createTime},</if>
  92. <if test="updateTime != null">#{updateTime},</if>
  93. <if test="createBy != null">#{createBy},</if>
  94. <if test="updateBy != null">#{updateBy},</if>
  95. <if test="completeWatchDate != null">#{completeWatchDate},</if>
  96. <if test="completeWatchCount != null">#{completeWatchCount},</if>
  97. <if test="watchTimes != null">#{watchTimes},</if>
  98. <if test="createDate != null">#{createDate},</if>
  99. </trim>
  100. </insert>
  101. <update id="updateFsUserCourseCount" parameterType="FsUserCourseCount">
  102. update fs_user_course_count
  103. <trim prefix="SET" suffixOverrides=",">
  104. <if test="userId != null">user_id = #{userId},</if>
  105. <if test="watchCourseCount != null">watch_course_count = #{watchCourseCount},</if>
  106. <if test="missCourseCount != null">miss_course_count = #{missCourseCount},</if>
  107. <if test="missCourseStatus != null">miss_course_status = #{missCourseStatus},</if>
  108. <if test="missCourseDays != null">miss_course_days = #{missCourseDays},</if>
  109. <if test="courseIds != null">course_ids = #{courseIds},</if>
  110. <if test="partCourseCount != null">part_course_count = #{partCourseCount},</if>
  111. <if test="lastWatchDate != null">last_watch_date = #{lastWatchDate},</if>
  112. <if test="status != null">status = #{status},</if>
  113. <if test="stopWatchDays != null">stop_watch_days = #{stopWatchDays},</if>
  114. <if test="createTime != null">create_time = #{createTime},</if>
  115. <if test="updateTime != null">update_time = #{updateTime},</if>
  116. <if test="createBy != null">create_by = #{createBy},</if>
  117. <if test="updateBy != null">update_by = #{updateBy},</if>
  118. <if test="completeWatchDate != null">complete_watch_date = #{completeWatchDate},</if>
  119. <if test="completeWatchCount != null">complete_watch_count = #{completeWatchCount},</if>
  120. <if test="watchTimes != null">watch_times = #{watchTimes},</if>
  121. <if test="createDate != null">create_date = #{createDate},</if>
  122. </trim>
  123. where id = #{id}
  124. </update>
  125. <delete id="deleteFsUserCourseCountById" parameterType="Long">
  126. delete from fs_user_course_count where id = #{id}
  127. </delete>
  128. <delete id="deleteFsUserCourseCountByIds" parameterType="String">
  129. delete from fs_user_course_count where id in
  130. <foreach item="id" collection="array" open="(" separator="," close=")">
  131. #{id}
  132. </foreach>
  133. </delete>
  134. <select id="getCountResult" resultType="FsUserCourseCount">
  135. SELECT
  136. fwl.user_id,
  137. count( DISTINCT CASE WHEN fwl.log_type != 3 THEN fwl.video_id END ) AS watchCourseCount,
  138. count( DISTINCT CASE WHEN fwl.log_type = 3 THEN fwl.video_id END ) AS missCourseCount,
  139. IF
  140. ( count( DISTINCT CASE WHEN fwl.log_type = 3 THEN fwl.video_id END ) > 0, 1, 2 ) AS missCourseStatus,
  141. GROUP_CONCAT( DISTINCT fwl.period_id ) AS courseIds,
  142. count(DISTINCT fwl.period_id ) AS partCourseCount,
  143. max( CASE WHEN fwl.log_type = 2 THEN fwl.last_heartbeat_time END ) AS completeWatchDate,
  144. count( CASE WHEN fwl.log_type = 2 THEN fwl.log_id END ) AS completeWatchCount,
  145. count( CASE WHEN fwl.log_type != 3 THEN fwl.log_id END ) AS watch_times,
  146. DATE_FORMAT(fwl.create_time,'%Y-%m-%d 00:00:00') AS createTime,
  147. NOW() AS updateTime,
  148. DATE_FORMAT(fwl.create_time,'%Y-%m-%d') AS create_date,
  149. DATE (fwl.create_time ) AS lastDate
  150. FROM
  151. fs_course_watch_log fwl
  152. where fwl.send_type = 1 and fwl.create_time &gt;= DATE_SUB(CURDATE(), INTERVAL 7 DAY)
  153. GROUP BY
  154. fwl.user_id
  155. </select>
  156. <select id="getUserStatusAndLastWatchDate" resultType="FsUserCourseCount">
  157. SELECT
  158. fs_course_watch_log.user_id,
  159. Max( fs_course_watch_log.last_heartbeat_time ) AS lastWatchDate,
  160. Max( DATE ( fs_course_watch_log.create_time ) ) AS lastDate,
  161. CASE
  162. WHEN fs_course_watch_log.log_type = 1
  163. OR fs_course_watch_log.log_type = 2 THEN
  164. 1
  165. WHEN fs_course_watch_log.log_type = 4 THEN
  166. 2
  167. WHEN fs_course_watch_log.log_type = 3 THEN
  168. 3
  169. END AS STATUS,
  170. DATEDIFF(
  171. DATE_FORMAT( NOW(), '%Y-%m-%d' ),
  172. DATE_FORMAT( fs_course_watch_log.last_heartbeat_time, '%Y-%m-%d' )) AS stop_watch_days
  173. FROM
  174. fs_course_watch_log
  175. WHERE
  176. fs_course_watch_log.send_type = 1
  177. AND fs_course_watch_log.create_time >= DATE_SUB( CURDATE(), INTERVAL 7 DAY )
  178. GROUP BY
  179. fs_course_watch_log.user_id, date(fs_course_watch_log.create_time)
  180. </select>
  181. <insert id="insertFsUserCourseCountTask" parameterType="FsUserCourseCount" useGeneratedKeys="true" keyProperty="id">
  182. insert into fs_user_course_count
  183. <trim prefix="(" suffix=")" suffixOverrides=",">
  184. <if test="userId != null">user_id,</if>
  185. <if test="watchCourseCount != null">watch_course_count,</if>
  186. <if test="missCourseCount != null">miss_course_count,</if>
  187. <if test="missCourseStatus != null">miss_course_status,</if>
  188. <if test="courseIds != null">course_ids,</if>
  189. <if test="partCourseCount != null">part_course_count,</if>
  190. <if test="lastWatchDate != null">last_watch_date,</if>
  191. <if test="status != null">status,</if>
  192. <if test="createTime != null">create_time,</if>
  193. <if test="updateTime != null">update_time,</if>
  194. <if test="createBy != null">create_by,</if>
  195. <if test="updateBy != null">update_by,</if>
  196. <if test="completeWatchDate != null">complete_watch_date,</if>
  197. <if test="completeWatchCount != null">complete_watch_count,</if>
  198. <if test="watchTimes != null">watch_times,</if>
  199. <if test="createDate != null">create_date,</if>
  200. </trim>
  201. <trim prefix="values (" suffix=")" suffixOverrides=",">
  202. <if test="userId != null">#{userId},</if>
  203. <if test="watchCourseCount != null">#{watchCourseCount},</if>
  204. <if test="missCourseCount != null">#{missCourseCount},</if>
  205. <if test="missCourseStatus != null">#{missCourseStatus},</if>
  206. <if test="courseIds != null">#{courseIds},</if>
  207. <if test="partCourseCount != null">#{partCourseCount},</if>
  208. <if test="lastWatchDate != null">#{lastWatchDate},</if>
  209. <if test="status != null">#{status},</if>
  210. <if test="createTime != null">#{createTime},</if>
  211. <if test="updateTime != null">#{updateTime},</if>
  212. <if test="createBy != null">#{createBy},</if>
  213. <if test="updateBy != null">#{updateBy},</if>
  214. <if test="completeWatchDate != null">#{completeWatchDate},</if>
  215. <if test="completeWatchCount != null">#{completeWatchCount},</if>
  216. <if test="watchTimes != null">#{watchTimes},</if>
  217. <if test="createDate != null">#{createDate},</if>
  218. </trim>
  219. on duplicate key update
  220. <trim suffixOverrides=",">
  221. <if test="watchCourseCount != null">watch_course_count = #{watchCourseCount},</if>
  222. <if test="missCourseCount != null">miss_course_count = #{missCourseCount},</if>
  223. <if test="missCourseStatus != null">miss_course_status = #{missCourseStatus},</if>
  224. <if test="courseIds != null">course_ids = #{courseIds},</if>
  225. <if test="partCourseCount != null">part_course_count = #{partCourseCount},</if>
  226. <if test="lastWatchDate != null">last_watch_date = #{lastWatchDate},</if>
  227. <if test="status != null">status = #{status},</if>
  228. <if test="completeWatchDate != null">complete_watch_date = #{completeWatchDate},</if>
  229. <if test="completeWatchCount != null">complete_watch_count = #{completeWatchCount},</if>
  230. <if test="watchTimes != null">watch_times = #{watchTimes},</if>
  231. <if test="updateTime != null">update_time = #{updateTime},</if>
  232. </trim>
  233. </insert>
  234. </mapper>