FsInquiryOrderMapper.xml 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  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.his.mapper.FsInquiryOrderMapper">
  6. <resultMap type="FsInquiryOrder" id="FsInquiryOrderResult">
  7. <result property="orderId" column="order_id" />
  8. <result property="orderSn" column="order_sn" />
  9. <result property="title" column="title" />
  10. <result property="imgs" column="imgs" />
  11. <result property="userId" column="user_id" />
  12. <result property="patientId" column="patient_id" />
  13. <result property="orderType" column="order_type" />
  14. <result property="money" column="money" />
  15. <result property="payMoney" column="pay_money" />
  16. <result property="payType" column="pay_type" />
  17. <result property="isPay" column="is_pay" />
  18. <result property="doctorId" column="doctor_id" />
  19. <result property="createTime" column="create_time" />
  20. <result property="payTime" column="pay_time" />
  21. <result property="status" column="status" />
  22. <result property="startTime" column="start_time" />
  23. <result property="finishTime" column="finish_time" />
  24. <result property="remark" column="remark" />
  25. <result property="isPing" column="is_ping" />
  26. <result property="departmentId" column="department_id" />
  27. <result property="inquiryType" column="inquiry_type" />
  28. <result property="inquirySubType" column="inquiry_sub_type" />
  29. <result property="patientJson" column="patient_json" />
  30. <result property="isReceive" column="is_receive" />
  31. <result property="tradeNo" column="trade_no" />
  32. <result property="isAudit" column="is_audit" />
  33. <result property="auditUserId" column="audit_user_id" />
  34. <result property="auditTime" column="audit_time" />
  35. <result property="userCouponId" column="user_coupon_id" />
  36. <result property="discountMoney" column="discount_money" />
  37. <result property="packageOrderId" column="package_order_id" />
  38. <result property="companyId" column="company_id" />
  39. <result property="companyUserId" column="company_user_id" />
  40. <result property="companyDeductMoney" column="company_deduct_money" />
  41. <result property="deptId" column="dept_id" />
  42. <result property="companyUserRemark" column="company_user_remark" />
  43. <result property="isSendSms" column="is_send_sms" />
  44. <result property="doctorRemark" column="doctor_remark" />
  45. <result property="source" column="source" />
  46. <result property="triageUserId" column="triage_user_id" />
  47. <result property="isUserInformation" column="is_user_information" />
  48. </resultMap>
  49. <sql id="selectFsInquiryOrderVo">
  50. select order_id,doctor_remark,is_user_information,source,triage_user_id, user_coupon_id,dept_id,company_deduct_money,company_id,company_user_id,company_user_remark,is_send_sms,package_order_id,discount_money, order_sn, title, imgs, user_id, patient_id, order_type, money, pay_money, pay_type, is_pay, doctor_id, create_time, pay_time, status, start_time, finish_time, remark, is_ping, department_id, inquiry_type, inquiry_sub_type, patient_json, is_receive, trade_no, is_audit, audit_user_id, audit_time from fs_inquiry_order
  51. </sql>
  52. <select id="selectFsInquiryOrderList" parameterType="FsInquiryOrder" resultMap="FsInquiryOrderResult">
  53. <include refid="selectFsInquiryOrderVo"/>
  54. <where>
  55. <if test="orderSn != null and orderSn != ''"> and order_sn = #{orderSn}</if>
  56. <if test="title != null and title != ''"> and title = #{title}</if>
  57. <if test="imgs != null and imgs != ''"> and imgs = #{imgs}</if>
  58. <if test="userId != null "> and user_id = #{userId}</if>
  59. <if test="patientId != null "> and patient_id = #{patientId}</if>
  60. <if test="orderType != null "> and order_type = #{orderType}</if>
  61. <if test="money != null "> and money = #{money}</if>
  62. <if test="payMoney != null "> and pay_money = #{payMoney}</if>
  63. <if test="payType != null "> and pay_type = #{payType}</if>
  64. <if test="isPay != null "> and is_pay = #{isPay}</if>
  65. <if test="doctorId != null "> and doctor_id = #{doctorId}</if>
  66. <if test="payTime != null "> and pay_time = #{payTime}</if>
  67. <if test="status != null "> and status = #{status}</if>
  68. <if test="startTime != null "> and start_time = #{startTime}</if>
  69. <if test="finishTime != null "> and finish_time = #{finishTime}</if>
  70. <if test="isPing != null "> and is_ping = #{isPing}</if>
  71. <if test="departmentId != null "> and department_id = #{departmentId}</if>
  72. <if test="inquiryType != null "> and inquiry_type = #{inquiryType}</if>
  73. <if test="inquirySubType != null "> and inquiry_sub_type = #{inquirySubType}</if>
  74. <if test="patientJson != null and patientJson != ''"> and patient_json = #{patientJson}</if>
  75. <if test="isReceive != null "> and is_receive = #{isReceive}</if>
  76. <if test="tradeNo != null and tradeNo != ''"> and trade_no = #{tradeNo}</if>
  77. <if test="isAudit != null "> and is_audit = #{isAudit}</if>
  78. <if test="auditUserId != null "> and audit_user_id = #{auditUserId}</if>
  79. <if test="auditTime != null "> and audit_time = #{auditTime}</if>
  80. <if test="isSendSms != null "> and is_send_sms = #{isSendSms}</if>
  81. <if test="isUserInformation != null "> and is_user_information = #{isUserInformation}</if>
  82. </where>
  83. </select>
  84. <select id="selectFsInquiryOrderByOrderId" parameterType="Long" resultMap="FsInquiryOrderResult">
  85. <include refid="selectFsInquiryOrderVo"/>
  86. where order_id = #{orderId}
  87. </select>
  88. <insert id="insertFsInquiryOrder" parameterType="FsInquiryOrder" useGeneratedKeys="true" keyProperty="orderId">
  89. insert into fs_inquiry_order
  90. <trim prefix="(" suffix=")" suffixOverrides=",">
  91. <if test="orderSn != null">order_sn,</if>
  92. <if test="title != null">title,</if>
  93. <if test="imgs != null">imgs,</if>
  94. <if test="userId != null">user_id,</if>
  95. <if test="patientId != null">patient_id,</if>
  96. <if test="orderType != null">order_type,</if>
  97. <if test="money != null">money,</if>
  98. <if test="payMoney != null">pay_money,</if>
  99. <if test="payType != null">pay_type,</if>
  100. <if test="isPay != null">is_pay,</if>
  101. <if test="doctorId != null">doctor_id,</if>
  102. <if test="createTime != null">create_time,</if>
  103. <if test="payTime != null">pay_time,</if>
  104. <if test="status != null">status,</if>
  105. <if test="startTime != null">start_time,</if>
  106. <if test="finishTime != null">finish_time,</if>
  107. <if test="remark != null">remark,</if>
  108. <if test="isPing != null">is_ping,</if>
  109. <if test="departmentId != null">department_id,</if>
  110. <if test="inquiryType != null">inquiry_type,</if>
  111. <if test="inquirySubType != null">inquiry_sub_type,</if>
  112. <if test="patientJson != null">patient_json,</if>
  113. <if test="isReceive != null">is_receive,</if>
  114. <if test="tradeNo != null">trade_no,</if>
  115. <if test="isAudit != null">is_audit,</if>
  116. <if test="auditUserId != null">audit_user_id,</if>
  117. <if test="auditTime != null">audit_time,</if>
  118. <if test="userCouponId != null">user_coupon_id,</if>
  119. <if test="discountMoney != null">discount_money,</if>
  120. <if test="packageOrderId != null">package_order_id,</if>
  121. <if test="companyId != null">company_id,</if>
  122. <if test="companyUserId != null">company_user_id,</if>
  123. <if test="companyDeductMoney != null">company_deduct_money,</if>
  124. <if test="deptId != null">dept_id,</if>
  125. <if test="companyUserRemark != null">company_user_remark,</if>
  126. <if test="isSendSms != null">is_send_sms,</if>
  127. <if test="doctorRemark != null">doctor_remark,</if>
  128. <if test="source != null">source,</if>
  129. <if test="triageUserId != null">triage_user_id,</if>
  130. <if test="isUserInformation != null">is_user_information,</if>
  131. </trim>
  132. <trim prefix="values (" suffix=")" suffixOverrides=",">
  133. <if test="orderSn != null">#{orderSn},</if>
  134. <if test="title != null">#{title},</if>
  135. <if test="imgs != null">#{imgs},</if>
  136. <if test="userId != null">#{userId},</if>
  137. <if test="patientId != null">#{patientId},</if>
  138. <if test="orderType != null">#{orderType},</if>
  139. <if test="money != null">#{money},</if>
  140. <if test="payMoney != null">#{payMoney},</if>
  141. <if test="payType != null">#{payType},</if>
  142. <if test="isPay != null">#{isPay},</if>
  143. <if test="doctorId != null">#{doctorId},</if>
  144. <if test="createTime != null">#{createTime},</if>
  145. <if test="payTime != null">#{payTime},</if>
  146. <if test="status != null">#{status},</if>
  147. <if test="startTime != null">#{startTime},</if>
  148. <if test="finishTime != null">#{finishTime},</if>
  149. <if test="remark != null">#{remark},</if>
  150. <if test="isPing != null">#{isPing},</if>
  151. <if test="departmentId != null">#{departmentId},</if>
  152. <if test="inquiryType != null">#{inquiryType},</if>
  153. <if test="inquirySubType != null">#{inquirySubType},</if>
  154. <if test="patientJson != null">#{patientJson},</if>
  155. <if test="isReceive != null">#{isReceive},</if>
  156. <if test="tradeNo != null">#{tradeNo},</if>
  157. <if test="isAudit != null">#{isAudit},</if>
  158. <if test="auditUserId != null">#{auditUserId},</if>
  159. <if test="auditTime != null">#{auditTime},</if>
  160. <if test="userCouponId != null">#{userCouponId},</if>
  161. <if test="discountMoney != null">#{discountMoney},</if>
  162. <if test="packageOrderId != null">#{packageOrderId},</if>
  163. <if test="companyId != null">#{companyId},</if>
  164. <if test="companyUserId != null">#{companyUserId},</if>
  165. <if test="companyDeductMoney != null">#{companyDeductMoney},</if>
  166. <if test="deptId != null">#{deptId},</if>
  167. <if test="companyUserRemark != null">#{companyUserRemark},</if>
  168. <if test="isSendSms != null">#{isSendSms},</if>
  169. <if test="doctorRemark != null">#{doctorRemark},</if>
  170. <if test="source != null">#{source},</if>
  171. <if test="triageUserId != null">#{triageUserId},</if>
  172. <if test="isUserInformation != null">#{isUserInformation},</if>
  173. </trim>
  174. </insert>
  175. <insert id="insertHsLog">
  176. INSERT INTO fs_inquiry_order_hs_log
  177. <trim prefix="(" suffix=")" suffixOverrides=",">
  178. <if test="responseBody != null">response_json,</if>
  179. <if test="inquiryOrderId != null">inquiry_order_id,</if>
  180. <if test="patientId != null">patient_id,</if>
  181. <if test="userId != null">user_id,</if>
  182. <if test="status != null">type,</if>
  183. <if test="responseData != null">decode_json,</if>
  184. <if test="bookNo != null">book_no,</if>
  185. create_time
  186. </trim>
  187. <trim prefix="VALUES (" suffix=")" suffixOverrides=",">
  188. <if test="responseBody != null">#{responseBody},</if>
  189. <if test="inquiryOrderId != null">#{inquiryOrderId},</if>
  190. <if test="patientId != null">#{patientId},</if>
  191. <if test="userId != null">#{userId},</if>
  192. <if test="status != null">#{status},</if>
  193. <if test="responseData != null">#{responseData},</if>
  194. <if test="bookNo != null">#{bookNo},</if>
  195. NOW()
  196. </trim>
  197. </insert>
  198. <update id="updateFsInquiryOrder" parameterType="FsInquiryOrder">
  199. update fs_inquiry_order
  200. <trim prefix="SET" suffixOverrides=",">
  201. <if test="orderSn != null">order_sn = #{orderSn},</if>
  202. <if test="title != null">title = #{title},</if>
  203. <if test="imgs != null">imgs = #{imgs},</if>
  204. <if test="userId != null">user_id = #{userId},</if>
  205. <if test="patientId != null">patient_id = #{patientId},</if>
  206. <if test="orderType != null">order_type = #{orderType},</if>
  207. <if test="money != null">money = #{money},</if>
  208. <if test="payMoney != null">pay_money = #{payMoney},</if>
  209. <if test="payType != null">pay_type = #{payType},</if>
  210. <if test="isPay != null">is_pay = #{isPay},</if>
  211. <if test="doctorId != null">doctor_id = #{doctorId},</if>
  212. <if test="createTime != null">create_time = #{createTime},</if>
  213. <if test="payTime != null">pay_time = #{payTime},</if>
  214. <if test="status != null">status = #{status},</if>
  215. <if test="startTime != null">start_time = #{startTime},</if>
  216. <if test="finishTime != null">finish_time = #{finishTime},</if>
  217. <if test="remark != null">remark = #{remark},</if>
  218. <if test="isPing != null">is_ping = #{isPing},</if>
  219. <if test="departmentId != null">department_id = #{departmentId},</if>
  220. <if test="inquiryType != null">inquiry_type = #{inquiryType},</if>
  221. <if test="inquirySubType != null">inquiry_sub_type = #{inquirySubType},</if>
  222. <if test="patientJson != null">patient_json = #{patientJson},</if>
  223. <if test="isReceive != null">is_receive = #{isReceive},</if>
  224. <if test="tradeNo != null">trade_no = #{tradeNo},</if>
  225. <if test="isAudit != null">is_audit = #{isAudit},</if>
  226. <if test="auditUserId != null">audit_user_id = #{auditUserId},</if>
  227. <if test="auditTime != null">audit_time = #{auditTime},</if>
  228. <if test="userCouponId != null">user_coupon_id = #{userCouponId},</if>
  229. <if test="discountMoney != null">discount_money = #{discountMoney},</if>
  230. <if test="packageOrderId != null">package_order_id = #{packageOrderId},</if>
  231. <if test="companyId != null">company_id = #{companyId},</if>
  232. <if test="companyUserId != null">company_user_id = #{companyUserId},</if>
  233. <if test="companyDeductMoney != null">company_deduct_money = #{companyDeductMoney},</if>
  234. <if test="deptId != null">dept_id = #{deptId},</if>
  235. <if test="companyUserRemark != null">company_user_remark = #{companyUserRemark},</if>
  236. <if test="isSendSms != null">is_send_sms = #{isSendSms},</if>
  237. <if test="doctorRemark != null">doctor_remark = #{doctorRemark},</if>
  238. <if test="source != null">source = #{source},</if>
  239. <if test="triageUserId != null">triage_user_id = #{triageUserId},</if>
  240. <if test="isUserInformation != null">is_user_information = #{isUserInformation},</if>
  241. </trim>
  242. where order_id = #{orderId}
  243. </update>
  244. <update id="closeOrder">
  245. update fs_inquiry_order set status = -1 where order_id = #{orderId}
  246. </update>
  247. <update id="updateHsLog">
  248. update fs_inquiry_order_hs_log set consult_room_json = #{jsonStr},update_time = NOW()
  249. WHERE inquiry_order_id = #{orderId}
  250. </update>
  251. <delete id="deleteFsInquiryOrderByOrderId" parameterType="Long">
  252. delete from fs_inquiry_order where order_id = #{orderId}
  253. </delete>
  254. <delete id="deleteFsInquiryOrderByOrderIds" parameterType="String">
  255. delete from fs_inquiry_order where order_id in
  256. <foreach item="orderId" collection="array" open="(" separator="," close=")">
  257. #{orderId}
  258. </foreach>
  259. </delete>
  260. <select id="selectFsInquiryOrderVOList_COUNT" parameterType="com.fs.his.vo.FsInquiryOrderListVO" resultType="Long">
  261. select count(1) from fs_inquiry_order io
  262. <if test="maps.doctorName != null or maps.doctorAccount != null"> LEFT JOIN fs_doctor dc ON io.doctor_id = dc.doctor_id </if>
  263. <if test="maps.phone != null and maps.phone != ''"> LEFT JOIN fs_user fu ON fu.user_id=io.user_id</if>
  264. <if test="maps.companyUserName != null or (maps.companyUserNickName != null and maps.companyUserNickName != '') "> LEFT JOIN company_user cu ON cu.user_id = io.company_user_id </if>
  265. where 1=1
  266. <if test="maps.orderSn != null and maps.orderSn != ''"> and io.order_sn = #{maps.orderSn}</if>
  267. <if test="maps.title != null and maps.title != ''"> and io.title = #{maps.title}</if>
  268. <if test="maps.userId != null"> and io.user_id = #{maps.userId}</if>
  269. <if test="maps.doctorName != null"> and dc.doctor_name like concat('%', #{maps.doctorName}, '%')</if>
  270. <if test="maps.patientId != null"> and io.patient_id = #{maps.patientId}</if>
  271. <if test="maps.patientName != null"> and io.patient_json like concat('%',#{maps.patientName},'%')</if>
  272. <if test="maps.orderType != null"> and io.order_type = #{maps.orderType}</if>
  273. <if test="maps.payType != null"> and io.pay_type = #{maps.payType}</if>
  274. <if test="maps.isPay != null"> and io.is_pay = #{maps.isPay}</if>
  275. <if test="maps.doctorId != null"> and io.doctor_id = #{maps.doctorId}</if>
  276. <if test="maps.status != null"> and io.status = #{maps.status}</if>
  277. <if test="maps.sTime != null"> and DATE(io.start_time) &gt;= DATE(#{maps.sTime})</if>
  278. <if test="maps.eTime != null"> and DATE(io.start_time) &lt;= DATE(#{maps.eTime})</if>
  279. <if test="maps.finishTime != null"> and DATE(io.finish_time) = DATE(#{maps.finishTime})</if>
  280. <if test="maps.isPing != null"> and io.is_ping = #{maps.isPing}</if>
  281. <if test="maps.departmentId != null"> and io.department_id = #{maps.departmentId}</if>
  282. <if test="maps.inquiryType != null"> and io.inquiry_type = #{maps.inquiryType}</if>
  283. <if test="maps.sendName != null"> and send.nick_name like concat(#{maps.sendName}, '%')</if>
  284. <if test="maps.phone != null and maps.phone != ''"> and fu.phone = #{maps.phone}</if>
  285. <if test="maps.companyId != null"> and io.company_id = #{maps.companyId}</if>
  286. <if test="maps.companyUserId != null"> and io.company_user_id = #{maps.companyUserId}</if>
  287. <if test="maps.companyUserName != null"> and cu.user_name = #{maps.companyUserName}</if>
  288. <if test="maps.inquirySubType != null"> and io.inquiry_sub_type = #{maps.inquirySubType}</if>
  289. <if test="maps.createTimeList != null"> and date_format(io.create_time,'%y%m%d') &gt;= date_format(#{maps.createTimeList[0]},'%y%m%d') AND date_format(io.create_time,'%y%m%d') &lt;= date_format(#{maps.createTimeList[1]},'%y%m%d')</if>
  290. <if test="maps.payTimeList != null"> and date_format(io.pay_time,'%y%m%d') &gt;= date_format(#{maps.payTimeList[0]},'%y%m%d') AND date_format(io.pay_time,'%y%m%d') &lt;= date_format(#{maps.payTimeList[1]},'%y%m%d')</if>
  291. <if test="maps.deptId != null"> AND (io.dept_id = #{maps.deptId} OR io.dept_id IN (SELECT t.dept_id FROM company_dept t WHERE find_in_set(#{maps.deptId}, ancestors)))</if>
  292. <if test="maps.inquirySubType != null"> and io.inquiry_sub_type = #{maps.inquirySubType}</if>
  293. <if test="maps.doctorAccount != null"> and dc.account = #{maps.doctorAccount}</if>
  294. <if test="maps.companyUserNickName != null and maps.companyUserNickName != ''"> and cu.nick_name like concat( #{maps.companyUserNickName}, '%')</if>
  295. </select>
  296. <!--只查询有首诊图片路径的数据上传-->
  297. <select id="selectNeedUploadData" resultType="com.fs.his.domain.FsInquiryOrderDTO">
  298. SELECT
  299. fio.*,
  300. fior.patient_json->>'$.reportImages' as reportImages,
  301. fior.inquiry_result as inquiryResult,
  302. fp.patient_name,
  303. fd.id_card as idCard,
  304. fd.sex as sex,
  305. fp.self_med_history as selfMedHistory,
  306. fd.doctor_name,
  307. fh.hospital_name as json,
  308. fdp.dept_name as deptName,
  309. fdp.dept_code as deptCode,
  310. fd.certificate_code as certificateCode
  311. FROM fs_inquiry_order fio
  312. INNER JOIN fs_inquiry_order_report fior ON fior.order_id = fio.order_id
  313. LEFT JOIN fs_doctor fd ON fd.doctor_id = fio.doctor_id
  314. LEFT JOIN fs_hospital fh ON fd.hospital_id = fh.hospital_id
  315. LEFT JOIN fs_department fdp ON fdp.dept_id = fio.department_id
  316. LEFT JOIN fs_patient fp ON fp.patient_id = fio.patient_id
  317. WHERE
  318. fio.create_time >= #{date}
  319. AND fior.patient_json IS NOT NULL
  320. AND fior.patient_json->>'$.reportImages' != '';
  321. </select>
  322. <select id="selectHsLog" resultType="com.fs.course.param.InquiryOrderHsLog">
  323. select id,
  324. response_json,
  325. inquiry_order_id,
  326. patient_id,
  327. user_id,
  328. type,
  329. decode_json,
  330. book_no
  331. from
  332. fs_inquiry_order_hs_log
  333. where
  334. inquiry_order_id = #{inquiryOrderId}
  335. and type = 1
  336. </select>
  337. </mapper>