SopUserLogsInfoMapper.xml 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352
  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.sop.mapper.SopUserLogsInfoMapper">
  6. <!-- 返回结果映射 -->
  7. <resultMap id="SopUserLogsInfoResult" type="com.fs.sop.domain.SopUserLogsInfo">
  8. <id property="id" column="id"/>
  9. <result property="sopId" column="sop_id"/>
  10. <result property="userLogsId" column="user_logs_id"/>
  11. <result property="externalContactId" column="external_contact_id" jdbcType="VARCHAR"/>
  12. <result property="qwUserId" column="qw_user_id" jdbcType="VARCHAR"/>
  13. <result property="corpId" column="corp_id" jdbcType="VARCHAR"/>
  14. <result property="externalId" column="external_id" />
  15. <result property="fsUserId" column="fs_user_id"/>
  16. <result property="externalUserName" column="external_user_name" jdbcType="VARCHAR"/>
  17. <result property="createTime" column="create_time" jdbcType="VARCHAR" />
  18. <result property="crtTime" column="crt_Time" />
  19. <result property="updateTime" column="update_time" jdbcType="VARCHAR" />
  20. <result property="tagIds" column="tag_ids" jdbcType="VARCHAR" />
  21. <result property="isDaysNotStudy" column="is_days_not_study"/>
  22. <result property="grade" column="grade"/>
  23. </resultMap>
  24. <sql id="selectSopUserLogsInfoVo">
  25. select *
  26. from sop_user_logs_info
  27. </sql>
  28. <select id="selectSopUserLogsInfoById" parameterType="String" resultMap="SopUserLogsInfoResult">
  29. <include refid="selectSopUserLogsInfoVo"/>
  30. where id = #{id}
  31. </select>
  32. <select id="selectSopUserLogsInfoByIds" parameterType="java.util.List" resultMap="SopUserLogsInfoResult">
  33. <include refid="selectSopUserLogsInfoVo"/>
  34. WHERE id IN
  35. <foreach collection="ids" item="id" open="(" separator="," close=")">
  36. #{id}
  37. </foreach>
  38. </select>
  39. <!-- 根据ID更新记录 -->
  40. <update id="updateSopUserLogsInfoToTime" parameterType="com.fs.sop.domain.SopUserLogsInfo">
  41. UPDATE sop_user_logs_info
  42. SET user_logs_id=#{data.userLogsId},create_time= Date(#{data.createTime}),update_time=#{data.updateTime}
  43. WHERE id = #{data.id}
  44. </update>
  45. <update id="insertSopUserLogsInfo" parameterType="com.fs.sop.domain.SopUserLogsInfo" useGeneratedKeys="false">
  46. INSERT INTO sop_user_logs_info
  47. <trim prefix="(" suffix=")" suffixOverrides=",">
  48. <if test="sopId != null">sop_id,</if>
  49. <if test="userLogsId != null">user_logs_id,</if>
  50. <if test="externalContactId != null">external_contact_id,</if>
  51. <if test="externalId != null">external_id,</if>
  52. <if test="qwUserId != null">qw_user_id,</if>
  53. <if test="corpId != null">corp_id,</if>
  54. <if test="fsUserId != null">fs_user_id,</if>
  55. <if test="externalUserName != null">external_user_name,</if>
  56. <if test="crtTime != null">crt_Time,</if>
  57. <if test="createTime != null">create_time,</if>
  58. <if test="updateTime != null">update_time,</if>
  59. </trim>
  60. <trim prefix="VALUES (" suffix=")" suffixOverrides=",">
  61. <if test="sopId != null">#{sopId},</if>
  62. <if test="userLogsId != null">#{userLogsId},</if>
  63. <if test="externalContactId != null">#{externalContactId},</if>
  64. <if test="externalId != null">#{externalId},</if>
  65. <if test="qwUserId != null">#{qwUserId},</if>
  66. <if test="corpId != null">#{corpId},</if>
  67. <if test="fsUserId != null">#{fsUserId},</if>
  68. <if test="externalUserName != null">#{externalUserName},</if>
  69. <if test="crtTime != null">#{crtTime},</if>
  70. <if test="createTime != null">#{createTime},</if>
  71. <if test="updateTime != null">#{updateTime},</if>
  72. </trim>
  73. </update>
  74. <update id="updateSopUserLogsInfoFsUserIdById" parameterType="java.util.List" useGeneratedKeys="false">
  75. UPDATE sop_user_logs_info
  76. SET
  77. fs_user_id = #{userId}
  78. WHERE id IN
  79. <foreach collection="data" item="log" open="(" separator="," close=")">
  80. #{log.id}
  81. </foreach>
  82. </update>
  83. <!-- 根据ID更新记录 -->
  84. <update id="updateById" parameterType="com.fs.sop.domain.SopUserLogsInfo">
  85. UPDATE sop_user_logs_info
  86. <trim prefix="SET" suffixOverrides=",">
  87. <if test="sopId != null"> sop_id = #{sopId},</if>
  88. <if test="userLogsId != null"> user_logs_id = #{userLogsId},</if>
  89. <if test="externalContactId != null"> external_contact_id = #{externalContactId},</if>
  90. <if test="qwUserId != null"> qw_user_id = #{qwUserId},</if>
  91. <if test="corpId != null"> corp_id = #{corpId},</if>
  92. <if test="externalId != null"> external_id = #{externalId},</if>
  93. <if test="fsUserId != null"> fs_user_id = #{fsUserId},</if>
  94. <if test="externalUserName != null"> external_user_name = #{externalUserName},</if>
  95. </trim>
  96. WHERE id = #{id}
  97. </update>
  98. <!-- 根据ID删除记录 -->
  99. <delete id="deleteById" parameterType="String">
  100. DELETE FROM sop_user_logs_info WHERE id = #{id}
  101. </delete>
  102. <delete id="deleteSopUserLogsInfoByIds" parameterType="String">
  103. delete from sop_user_logs_info where id in
  104. <foreach item="id" collection="array" open="(" separator="," close=")">
  105. #{id}
  106. </foreach>
  107. </delete>
  108. <delete id="deleteByQwUserIdAndCorpIdToContactId" parameterType="String">
  109. DELETE FROM sop_user_logs_info WHERE qw_user_id = #{qwUserId} and corp_id = #{corpId} and external_contact_id = #{externalContactId}
  110. </delete>
  111. <delete id="deleteByQwUserIdAndCorpIdToContactIdByChat" parameterType="String">
  112. DELETE FROM sop_user_logs_info_chat WHERE qw_user_id = #{qwUserId} and corp_id = #{corpId} and external_contact_id = #{externalContactId}
  113. </delete>
  114. <delete id="deleteByQwUserIdAndCorpIdToContactIdList" parameterType="com.fs.sop.params.DeleteQwSopParam">
  115. DELETE FROM sop_user_logs_info
  116. WHERE qw_user_id = #{data.qwUserId}
  117. and corp_id = #{data.corpId}
  118. and external_contact_id IN
  119. <foreach collection="data.externalUserIds" item="extId" open="(" separator="," close=")">
  120. #{extId}
  121. </foreach>
  122. </delete>
  123. <delete id="deleteByQwUserIdAndCorpIdToContactIdByChatList" parameterType="com.fs.sop.params.DeleteQwSopParam">
  124. DELETE FROM sop_user_logs_info_chat
  125. WHERE qw_user_id = #{data.qwUserId}
  126. and corp_id = #{data.corpId}
  127. and external_contact_id IN
  128. <foreach collection="data.externalUserIds" item="extId" open="(" separator="," close=")">
  129. #{extId}
  130. </foreach>
  131. </delete>
  132. <delete id="deleteSopUserLogsInfoBySopIds" parameterType="map">
  133. DELETE FROM sop_user_logs_info WHERE sop_id IN
  134. <foreach item="sopId" index="index" collection="sopIds"
  135. open="(" separator="," close=")">
  136. #{sopId}
  137. </foreach>
  138. </delete>
  139. <delete id="deleteBySopIdToContactId" parameterType="com.fs.sop.params.SopUserLogsInfoDelParam">
  140. DELETE FROM sop_user_logs_info
  141. WHERE sop_id = #{data.sopId}
  142. and qw_user_id = #{data.qwUserId}
  143. and corp_id = #{data.corpId}
  144. and external_id = #{data.externalId}
  145. </delete>
  146. <delete id="deleteBySopIdToContactIdChat" parameterType="com.fs.sop.params.SopUserLogsInfoDelParam">
  147. DELETE FROM sop_user_logs_info_chat
  148. WHERE sop_id = #{data.sopId}
  149. and qw_user_id = #{data.qwUserId}
  150. and corp_id = #{data.corpId}
  151. and external_id = #{data.externalId}
  152. </delete>
  153. <delete id="deleteSopUserLogsInfoByUserLogsIds" parameterType="map">
  154. DELETE FROM sop_user_logs_info WHERE user_logs_id IN
  155. <foreach item="userLogsId" index="index" collection="userLogsIds"
  156. open="(" separator="," close=")">
  157. #{userLogsId}
  158. </foreach>
  159. </delete>
  160. <!-- 根据ID查询单条记录 -->
  161. <select id="selectById" parameterType="String" resultMap="SopUserLogsInfoResult">
  162. SELECT id, sop_id, user_logs_id, external_contact_id,qw_user_id,corp_id,external_id, fs_user_id, external_user_name,create_time,crt_Time,update_time,grade
  163. FROM sop_user_logs_info
  164. WHERE id = #{id}
  165. </select>
  166. <select id="selectSopUserLogsInfoList" parameterType="com.fs.sop.domain.SopUserLogsInfo" resultMap="SopUserLogsInfoResult">
  167. <include refid="selectSopUserLogsInfoVo"/>
  168. <where>
  169. <if test="sopId != null">and sop_id = #{sopId}</if>
  170. <if test="userLogsId != null">and user_logs_id = #{userLogsId}</if>
  171. <if test="externalContactId != null">and external_contact_id = #{externalContactId}</if>
  172. <if test="qwUserId != null">and qw_user_id = #{qwUserId}</if>
  173. <if test="corpId != null">and corp_id = #{corpId}</if>
  174. <if test="externalId != null">and external_id = #{externalId}</if>
  175. <if test="fsUserId != null">and fs_user_id = #{fsUserId}</if>
  176. <if test="fsUserIdStatus != null and fsUserIdStatus==1 ">and fs_user_id is not null and fs_user_id !=0 </if>
  177. <if test="fsUserIdStatus != null and fsUserIdStatus==2 ">and (fs_user_id is null or fs_user_id =0)</if>
  178. <if test="externalUserName != null">and external_user_name like CONCAT('%', #{externalUserName}, '%')</if>
  179. <if test="createTime != null">and create_time = #{createTime}</if>
  180. <if test="crtTime != null">and crt_Time = #{crtTime}</if>
  181. <if test="updateTime != null">and updateTime = #{updateTime}</if>
  182. </where>
  183. order by crt_Time desc
  184. </select>
  185. <select id="selectSopUserLogsInfo" parameterType="com.fs.sop.domain.SopUserLogsInfo" resultMap="SopUserLogsInfoResult">
  186. <include refid="selectSopUserLogsInfoVo"/>
  187. <where>
  188. <if test="sopId != null">and sop_id = #{sopId}</if>
  189. <if test="externalContactId != null">and external_contact_id = #{externalContactId}</if>
  190. <if test="qwUserId != null">and qw_user_id = #{qwUserId}</if>
  191. <if test="corpId != null">and corp_id = #{corpId}</if>
  192. </where>
  193. limit 1
  194. </select>
  195. <select id="selectSopUserLogsInfoByCheckJobTransfer" parameterType="com.fs.sop.domain.SopUserLogsInfo" resultMap="SopUserLogsInfoResult">
  196. select id,user_logs_id
  197. from sop_user_logs_info
  198. where sop_id = #{sopId} and qw_user_id=#{qwUserId} and corp_id=#{corpId} and external_contact_id=#{externalContactId} limit 1
  199. </select>
  200. <select id="selectSopUserLogsInfoListBySopId" parameterType="String" resultMap="SopUserLogsInfoResult">
  201. select
  202. id, sop_id, user_logs_id, external_contact_id,qw_user_id,corp_id,external_id,
  203. fs_user_id, external_user_name,create_time,crt_Time,update_time
  204. from sop_user_logs_info where sop_id = #{sopId} and user_logs_id=#{userLogsId}
  205. </select>
  206. <select id="selectRestoreByIsDaysNotStudy" parameterType="String" resultMap="SopUserLogsInfoResult">
  207. select
  208. id,external_id
  209. from sop_user_logs_info
  210. where sop_id = #{sopId}
  211. and user_logs_id=#{userLogsId}
  212. and is_days_not_study=1
  213. </select>
  214. <!-- 查询所有记录 -->
  215. <select id="selectAll" resultMap="SopUserLogsInfoResult">
  216. SELECT id, sop_id, user_logs_id, external_contact_id,qw_user_id,corp_id,external_id,
  217. fs_user_id, external_user_name,create_time,crt_Time,update_time
  218. FROM sop_user_logs_info
  219. </select>
  220. <select id="selectChatSopUserLogsInfo" resultType="com.fs.sop.domain.SopUserLogsInfo">
  221. select id, sop_id, user_logs_id, external_contact_id,qw_user_id,corp_id,external_id,
  222. fs_user_id, external_user_name,create_time,crt_Time,update_time
  223. from sop_user_logs_info_chat
  224. <where>
  225. <if test="sopId != null">and sop_id = #{sopId}</if>
  226. <if test="externalContactId != null">and external_contact_id = #{externalContactId}</if>
  227. <if test="qwUserId != null">and qw_user_id = #{qwUserId}</if>
  228. <if test="corpId != null">and corp_id = #{corpId}</if>
  229. <if test="externalId != null">and external_id = #{externalId}</if>
  230. </where>
  231. limit 1
  232. </select>
  233. <select id="selectChatSopUserLogsByQwUserId" resultMap="SopUserLogsInfoResult">
  234. SELECT
  235. id, sop_id, user_logs_id, external_contact_id,qw_user_id,corp_id,external_id,
  236. fs_user_id, external_user_name,create_time,crt_Time,update_time
  237. FROM sop_user_logs_info_chat
  238. where qw_user_id=#{qwUserId} and corp_id=#{corpId} AND crt_Time > NOW() - INTERVAL 24 HOUR;
  239. </select>
  240. <!-- 批量插入 SopUserLogsInfo -->
  241. <insert id="batchInsertSopUserLogsInfo" parameterType="java.util.List" useGeneratedKeys="false">
  242. INSERT INTO sop_user_logs_info
  243. (
  244. sop_id, user_logs_id, external_contact_id,qw_user_id,corp_id, external_id,
  245. fs_user_id, external_user_name
  246. )
  247. VALUES
  248. <foreach collection="SopUserLogsInfo" item="log" separator=",">
  249. (
  250. #{log.sopId},
  251. #{log.userLogsId},
  252. #{log.externalContactId},
  253. #{log.qwUserId},
  254. #{log.corpId},
  255. #{log.externalId},
  256. #{log.fsUserId},
  257. #{log.externalUserName}
  258. )
  259. </foreach>
  260. ON DUPLICATE KEY UPDATE
  261. update_time = Now()
  262. </insert>
  263. <update id="insertChatSopUserLogsInfo" parameterType="com.fs.sop.domain.SopUserLogsInfo" useGeneratedKeys="false">
  264. INSERT INTO sop_user_logs_info_chat
  265. <trim prefix="(" suffix=")" suffixOverrides=",">
  266. <if test="sopId != null">sop_id,</if>
  267. <if test="userLogsId != null">user_logs_id,</if>
  268. <if test="externalContactId != null">external_contact_id,</if>
  269. <if test="externalId != null">external_id,</if>
  270. <if test="qwUserId != null">qw_user_id,</if>
  271. <if test="corpId != null">corp_id,</if>
  272. <if test="fsUserId != null">fs_user_id,</if>
  273. <if test="externalUserName != null">external_user_name,</if>
  274. <if test="crtTime != null">crt_Time,</if>
  275. <if test="createTime != null">create_time,</if>
  276. <if test="updateTime != null">update_time,</if>
  277. </trim>
  278. <trim prefix="VALUES (" suffix=")" suffixOverrides=",">
  279. <if test="sopId != null">#{sopId},</if>
  280. <if test="userLogsId != null">#{userLogsId},</if>
  281. <if test="externalContactId != null">#{externalContactId},</if>
  282. <if test="externalId != null">#{externalId},</if>
  283. <if test="qwUserId != null">#{qwUserId},</if>
  284. <if test="corpId != null">#{corpId},</if>
  285. <if test="fsUserId != null">#{fsUserId},</if>
  286. <if test="externalUserName != null">#{externalUserName},</if>
  287. <if test="crtTime != null">#{crtTime},</if>
  288. <if test="createTime != null">#{createTime},</if>
  289. <if test="updateTime != null">#{updateTime},</if>
  290. </trim>
  291. </update>
  292. <update id="batchUpdateSopUserLogsInfoToTime" parameterType="com.fs.sop.params.BatchSopUserLogsInfoParamU">
  293. UPDATE sop_user_logs_info
  294. <trim prefix="SET" suffixOverrides=",">
  295. <if test="userLogsId != null">user_logs_id = #{userLogsId},</if>
  296. update_time = NOW()
  297. </trim>
  298. WHERE id IN
  299. <foreach collection="ids" item="id" open="(" separator="," close=")">
  300. #{id}
  301. </foreach>
  302. </update>
  303. <select id="selectEerGroup" resultMap="SopUserLogsInfoResult">
  304. select s.user_logs_id,ANY_VALUE(s.sop_id) sop_id,ANY_VALUE(s.qw_user_id) qw_user_id,ANY_VALUE(s.corp_id) corp_id from sop_user_logs_info s LEFT JOIN sop_user_logs ss ON s.user_logs_id=ss.id where create_time='2025-02-11' and ss.id is null GROUP BY s.user_logs_id
  305. </select>
  306. <select id="selectSopUserLogsInfoListByUserLogsId" resultMap="SopUserLogsInfoResult">
  307. select * from sop_user_logs_info where user_logs_id=#{id}
  308. </select>
  309. </mapper>