FsCourseRedPacketLogMapper.xml 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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.course.mapper.FsCourseRedPacketLogMapper">
  6. <resultMap type="FsCourseRedPacketLog" id="FsCourseRedPacketLogResult">
  7. <result property="logId" column="log_id" />
  8. <result property="courseId" column="course_id" />
  9. <result property="userId" column="user_id" />
  10. <result property="videoId" column="video_id" />
  11. <result property="companyUserId" column="company_user_id" />
  12. <result property="companyId" column="company_id" />
  13. <result property="amount" column="amount" />
  14. <result property="createTime" column="create_time" />
  15. <result property="qwUserId" column="qw_user_id" />
  16. <result property="outBatchNo" column="out_batch_no" />
  17. <result property="status" column="status" />
  18. <result property="updateTime" column="update_time" />
  19. <result property="watchLogId" column="watch_log_id" />
  20. <result property="remark" column="remark" />
  21. </resultMap>
  22. <sql id="selectFsCourseRedPacketLogVo">
  23. select log_id,watch_log_id, remark,out_batch_no,status,update_time,course_id, user_id, video_id, company_user_id, company_id, amount, create_time, qw_user_id from fs_course_red_packet_log
  24. </sql>
  25. <select id="selectFsCourseRedPacketLogList" parameterType="FsCourseRedPacketLog" resultMap="FsCourseRedPacketLogResult">
  26. <include refid="selectFsCourseRedPacketLogVo"/>
  27. <where>
  28. <if test="courseId != null "> and course_id = #{courseId}</if>
  29. <if test="userId != null "> and user_id = #{userId}</if>
  30. <if test="videoId != null "> and video_id = #{videoId}</if>
  31. <if test="companyUserId != null "> and company_user_id = #{companyUserId}</if>
  32. <if test="companyId != null "> and company_id = #{companyId}</if>
  33. <if test="amount != null "> and amount = #{amount}</if>
  34. <if test="qwUserId != null and qwUserId != ''"> and qw_user_id = #{qwUserId}</if>
  35. </where>
  36. </select>
  37. <select id="selectFsCourseRedPacketLogByLogId" parameterType="Long" resultMap="FsCourseRedPacketLogResult">
  38. <include refid="selectFsCourseRedPacketLogVo"/>
  39. where log_id = #{logId}
  40. </select>
  41. <select id="selectFsCourseRedPacketLogListVONew" resultType="com.fs.course.vo.FsCourseRedPacketLogListPVO">
  42. select
  43. watch.log_id,
  44. watch.user_id,
  45. uc.course_name,
  46. v.title as video_name,
  47. watch.log_type,
  48. watch.qw_external_contact_id,
  49. watch.qw_user_id,
  50. watch.course_id,
  51. watch.send_type,
  52. watch.video_id,
  53. l.create_time,
  54. SEC_TO_TIME(watch.duration) duration,
  55. l.amount,
  56. l.status,
  57. l.out_batch_no,
  58. v.title,u.nick_name as fsNickName,u.avatar as fsAvatar,u.phone,cu.nick_name company_user_name,c.company_name,qu.qw_user_name
  59. from fs_course_watch_log watch
  60. left join fs_course_red_packet_log l on watch.user_id = l.user_id and watch.video_id = l.video_id
  61. left join fs_user_course_video v on v.video_id = watch.video_id
  62. left join fs_user_course uc on uc.course_id = l.course_id
  63. left join fs_user u on u.user_id = watch.user_id
  64. left join company_user cu on cu.user_id=watch.company_user_id
  65. left join company c on c.company_id=watch.company_id
  66. LEFT JOIN qw_user qu on qu.id= watch.qw_user_id
  67. <where>
  68. <if test = ' userId !=null '> and watch.user_id = #{userId} </if>
  69. <if test = ' companyId !=null '> and watch.company_id = #{companyId} </if>
  70. <if test = ' companyUserName !=null '> and cu.nick_name like concat('%', #{companyUserName}, '%') </if>
  71. <if test = ' nickName !=null '> and u.nick_name like concat('%', #{nickName}, '%') </if>
  72. <if test = ' courseId !=null '> and watch.course_id = #{courseId} </if>
  73. <if test = ' videoId !=null '> and watch.video_id = #{videoId} </if>
  74. <if test = ' status !=null '> and l.status = #{status} </if>
  75. <if test = ' logType !=null '> and watch.log_type = #{logType} </if>
  76. <if test = ' phone !=null '> and u.phone = #{phone} </if>
  77. <if test = ' qwUserId !=null '> and watch.qw_user_id = #{qwUserId} </if>
  78. <if test="sTime != null"> and DATE(watch.create_time) &gt;= DATE(#{sTime})</if>
  79. <if test="eTime != null"> and DATE(watch.create_time) &lt;= DATE(#{eTime})</if>
  80. </where>
  81. order by watch.log_id desc
  82. </select>
  83. <!-- 查询新用户红包金额总和 -->
  84. <select id="getNewVipRedPackAmountByCompanyUserIdId" resultType="java.math.BigDecimal">
  85. select
  86. ifnull(sum(fcrpl.amount), 0)
  87. from fs_course_red_packet_log fcrpl
  88. inner join fs_user fu on fu.user_id = fcrpl.user_id and date(fu.create_time) = CURDATE()
  89. where fcrpl.company_user_id = #{companyUserId}
  90. </select>
  91. <insert id="insertFsCourseRedPacketLog" parameterType="FsCourseRedPacketLog" useGeneratedKeys="true" keyProperty="logId">
  92. insert into fs_course_red_packet_log
  93. <trim prefix="(" suffix=")" suffixOverrides=",">
  94. <if test="courseId != null">course_id,</if>
  95. <if test="userId != null">user_id,</if>
  96. <if test="videoId != null">video_id,</if>
  97. <if test="companyUserId != null">company_user_id,</if>
  98. <if test="companyId != null">company_id,</if>
  99. <if test="amount != null">amount,</if>
  100. <if test="createTime != null">create_time,</if>
  101. <if test="qwUserId != null">qw_user_id,</if>
  102. <if test="outBatchNo != null">out_batch_no,</if>
  103. <if test="status != null">status,</if>
  104. <if test="updateTime != null">update_time,</if>
  105. <if test="watchLogId != null">watch_log_id,</if>
  106. <if test="remark != null">remark,</if>
  107. </trim>
  108. <trim prefix="values (" suffix=")" suffixOverrides=",">
  109. <if test="courseId != null">#{courseId},</if>
  110. <if test="userId != null">#{userId},</if>
  111. <if test="videoId != null">#{videoId},</if>
  112. <if test="companyUserId != null">#{companyUserId},</if>
  113. <if test="companyId != null">#{companyId},</if>
  114. <if test="amount != null">#{amount},</if>
  115. <if test="createTime != null">#{createTime},</if>
  116. <if test="qwUserId != null">#{qwUserId},</if>
  117. <if test="outBatchNo != null">#{outBatchNo},</if>
  118. <if test="status != null">#{status},</if>
  119. <if test="updateTime != null">#{updateTime},</if>
  120. <if test="watchLogId != null">#{watchLogId},</if>
  121. <if test="remark != null">#{remark},</if>
  122. </trim>
  123. </insert>
  124. <update id="updateFsCourseRedPacketLog" parameterType="FsCourseRedPacketLog">
  125. update fs_course_red_packet_log
  126. <trim prefix="SET" suffixOverrides=",">
  127. <if test="courseId != null">course_id = #{courseId},</if>
  128. <if test="userId != null">user_id = #{userId},</if>
  129. <if test="videoId != null">video_id = #{videoId},</if>
  130. <if test="companyUserId != null">company_user_id = #{companyUserId},</if>
  131. <if test="companyId != null">company_id = #{companyId},</if>
  132. <if test="amount != null">amount = #{amount},</if>
  133. <if test="createTime != null">create_time = #{createTime},</if>
  134. <if test="qwUserId != null">qw_user_id = #{qwUserId},</if>
  135. <if test="outBatchNo != null">out_batch_no = #{outBatchNo},</if>
  136. <if test="status != null">status = #{status},</if>
  137. <if test="updateTime != null">update_time = #{updateTime},</if>
  138. <if test="watchLogId != null">watch_log_id = #{watchLogId},</if>
  139. <if test="remark != null">remark = #{remark},</if>
  140. </trim>
  141. where log_id = #{logId}
  142. </update>
  143. <delete id="deleteFsCourseRedPacketLogByLogId" parameterType="Long">
  144. delete from fs_course_red_packet_log where log_id = #{logId}
  145. </delete>
  146. <delete id="deleteFsCourseRedPacketLogByLogIds" parameterType="String">
  147. delete from fs_course_red_packet_log where log_id in
  148. <foreach item="logId" collection="array" open="(" separator="," close=")">
  149. #{logId}
  150. </foreach>
  151. </delete>
  152. </mapper>