SopUserLogsInfoMapper.xml 15 KB

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