ReceiptMapper.xml 44 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3. <mapper namespace="com.caimei365.order.mapper.ReceiptMapper">
  4. <insert id="insertReceipt" keyColumn="id" keyProperty="id" parameterType="com.caimei365.order.model.po.ReceiptPo"
  5. useGeneratedKeys="true">
  6. INSERT INTO cm_discern_receipt(payWay,
  7. payType,
  8. receiptType,
  9. receiptStatus,
  10. smsContent,
  11. smsMd5Code,
  12. receiptAmount,
  13. handlingFee,
  14. confirmType,
  15. receiptUserPermissionID,
  16. confirmUserPermissionID,
  17. reviewUserPermissionID,
  18. cancelUserPermissionID,
  19. noOrderReason,
  20. reviewReason,
  21. rebateRemarks,
  22. cancelReason,
  23. receiptDate,
  24. confirmDate,
  25. reviewDate,
  26. cancelDate,
  27. updateDate,
  28. delFlag)
  29. VALUES (#{payWay},
  30. #{payType},
  31. #{receiptType},
  32. #{receiptStatus},
  33. #{smsContent},
  34. #{smsMd5Code},
  35. #{receiptAmount},
  36. #{handlingFee},
  37. #{confirmType},
  38. #{receiptUserPermissionId},
  39. #{confirmUserPermissionId},
  40. #{reviewUserPermissionId},
  41. #{cancelUserPermissionId},
  42. #{noOrderReason},
  43. #{reviewReason},
  44. #{rebateRemarks},
  45. #{cancelReason},
  46. #{receiptDate},
  47. #{confirmDate},
  48. #{reviewDate},
  49. #{cancelDate},
  50. #{updateDate},
  51. #{delFlag})
  52. </insert>
  53. <update id="updateReceipt" parameterType="com.caimei365.order.model.po.ReceiptPo">
  54. update cm_discern_receipt
  55. <set>
  56. <if test="shopName != null">
  57. shopName=#{shopName},
  58. </if>
  59. <if test="shopId !=null">
  60. shopID=#{shopId},
  61. </if>
  62. <if test="shopOrderId !=null">
  63. shopOrderID=#{shopOrderId},
  64. </if>
  65. <if test="newReceiptType != null">
  66. newReceiptType = #{newReceiptType},
  67. </if>
  68. <if test="payWay != null">
  69. payWay = #{payWay},
  70. </if>
  71. <if test="payType != null">
  72. payType = #{payType},
  73. </if>
  74. <if test="receiptType != null">
  75. receiptType = #{receiptType},
  76. </if>
  77. <if test="receiptStatus != null">
  78. receiptStatus = #{receiptStatus},
  79. </if>
  80. <if test="smsContent != null">
  81. smsContent = #{smsContent},
  82. </if>
  83. <if test="smsMd5Code != null">
  84. smsMd5Code = #{smsMd5Code},
  85. </if>
  86. <if test="orderFlag != null">
  87. orderFlag = #{orderFlag},
  88. </if>
  89. <if test="receiptAmount != null">
  90. receiptAmount = #{receiptAmount},
  91. </if>
  92. <if test="handlingFee != null">
  93. handlingFee = #{handlingFee},
  94. </if>
  95. <if test="confirmType != null">
  96. confirmType = #{confirmType},
  97. </if>
  98. <if test="confirmUserPermissionId != null">
  99. confirmUserPermissionID = #{confirmUserPermissionId},
  100. </if>
  101. <if test="reviewUserPermissionId != null">
  102. reviewUserPermissionID = #{reviewUserPermissionId},
  103. </if>
  104. <if test="cancelUserPermissionId != null">
  105. cancelUserPermissionID = #{cancelUserPermissionId},
  106. </if>
  107. <if test="noOrderReason != null">
  108. noOrderReason = #{noOrderReason},
  109. </if>
  110. <if test="reviewReason != null">
  111. reviewReason = #{reviewReason},
  112. </if>
  113. <if test="cancelReason != null">
  114. cancelReason = #{cancelReason},
  115. </if>
  116. <if test="receiptDate != null">
  117. receiptDate = #{receiptDate},
  118. </if>
  119. <if test="confirmDate != null">
  120. confirmDate = #{confirmDate},
  121. </if>
  122. <if test="reviewDate != null">
  123. reviewDate = #{reviewDate},
  124. </if>
  125. <if test="cancelDate != null">
  126. cancelDate = #{cancelDate},
  127. </if>
  128. <if test="updateDate != null">
  129. updateDate = #{updateDate},
  130. </if>
  131. <if test="delFlag != null">
  132. delFlag = #{delFlag},
  133. </if>
  134. <if test="rebateRemarks != null">
  135. rebateRemarks = #{rebateRemarks},
  136. </if>
  137. </set>
  138. where id = #{id}
  139. </update>
  140. <update id="updateOpenidByMobile">
  141. UPDATE cm_receipt_user
  142. SET openid=#{openid},
  143. unionId=#{unionId}
  144. WHERE mobile = #{mobile}
  145. </update>
  146. <update id="deleteReceiptRelation">
  147. UPDATE cm_receipt_order_relation
  148. SET delFlag = '1'
  149. WHERE receiptID = #{receiptId}
  150. </update>
  151. <update id="updateShopOrderPayStatus">
  152. UPDATE cm_shop_order
  153. SET payStatus = #{payStatus}
  154. WHERE shopOrderID = #{shopOrderId}
  155. </update>
  156. <update id="updateShopRebateAmount">
  157. UPDATE shop s
  158. SET s.rebateAmount = (IFNULL(s.rebateAmount, 0) + #{amount}),
  159. s.ableRebateAmount = (IFNULL(s.ableRebateAmount, 0) + #{amount})
  160. WHERE s.shopID = #{shopId}
  161. </update>
  162. <select id="getReceiptUserByOpenid" resultType="com.caimei365.order.model.vo.ReceiptUserVo">
  163. SELECT DISTINCT id, user_type AS userType, name, mobile, openid, unionId, password
  164. FROM cm_receipt_user
  165. WHERE openid = #{openid}
  166. AND del_flag = 0
  167. </select>
  168. <select id="getReceiptUserByMobile" resultType="com.caimei365.order.model.vo.ReceiptUserVo">
  169. SELECT DISTINCT id, user_type AS userType, name, mobile, openid, unionId, password
  170. FROM cm_receipt_user
  171. WHERE mobile = #{mobile}
  172. AND del_flag = 0
  173. </select>
  174. <select id="getReceiptUserNameById" resultType="java.lang.String">
  175. SELECT DISTINCT name
  176. FROM cm_receipt_user
  177. WHERE id = #{id}
  178. </select>
  179. <select id="getPermissionsByUserId" resultType="java.lang.Integer">
  180. SELECT permission_id
  181. FROM cm_receipt_user_permission
  182. WHERE user_id = #{userId}
  183. </select>
  184. <select id="getReceiptType" resultType="com.caimei365.order.model.vo.cmOfflineCollectionVo">
  185. SELECT TYPE AS id, bankAccount AS TYPE FROM cm_offline_collection WHERE isDisable != 0 ORDER BY id
  186. </select>
  187. <select id="getReceiptTypeById" resultType="com.caimei365.order.model.vo.ReceiptTypeVo">
  188. SELECT `id`, `type`
  189. FROM cm_receipt_type
  190. WHERE id = #{id}
  191. </select>
  192. <select id="getReceiptTypeStrById" resultType="java.lang.String">
  193. SELECT `type`
  194. FROM cm_receipt_type
  195. WHERE id = #{id}
  196. </select>
  197. <select id="getReceivablesTypeId" resultType="java.lang.Integer">
  198. SELECT DISTINCT IFNULL(id, 0)
  199. FROM cm_receipt_type
  200. WHERE type = #{type}
  201. </select>
  202. <select id="getPaidAmountByOrderId" resultType="java.lang.Double">
  203. SELECT IFNULL(SUM(cror.associateAmount), 0)
  204. FROM cm_receipt_order_relation cror
  205. LEFT JOIN cm_discern_receipt cdr ON cror.receiptID = cdr.id
  206. <where>
  207. <if test="orderId != null and orderId != ''">
  208. AND cror.orderID = #{orderId} AND cror.relationType = 2
  209. </if>
  210. AND cdr.receiptStatus in(2,3)
  211. AND cdr.payWay != '3'
  212. AND cdr.delFlag = '0'
  213. AND cror.delFlag = '0'
  214. </where>
  215. </select>
  216. <select id="getUncheckAmount" resultType="java.lang.Double">
  217. SELECT IFNULL(SUM(cror.associateAmount), 0)
  218. FROM cm_receipt_order_relation cror
  219. LEFT JOIN cm_discern_receipt cdr ON cror.receiptID = cdr.id
  220. <where>
  221. <if test="orderId != null and orderId != ''">
  222. AND cror.orderID = #{orderId} AND cror.relationType = 2
  223. </if>
  224. AND cdr.receiptStatus = '2'
  225. AND cdr.delFlag = '0'
  226. AND cror.delFlag = '0'
  227. </where>
  228. </select>
  229. <select id="getReturnedAmount" resultType="java.lang.Double">
  230. SELECT IFNULL(SUM(returnedPurchaseFee), 0) FROM cm_returned_purchase
  231. <where>
  232. <if test="orderId != null and orderId != ''">
  233. AND orderID = #{orderId}
  234. </if>
  235. AND status = '2'
  236. </where>
  237. </select>
  238. <select id="getReceiptNumByOrderId" resultType="java.lang.Integer">
  239. SELECT IFNULL(SUM(a.num), 0)
  240. FROM cm_logistics_record a
  241. LEFT JOIN cm_logistics_batch b ON a.logisticsBatchID = b.id
  242. WHERE b.orderID = #{orderId}
  243. AND b.status = '1'
  244. </select>
  245. <select id="getReturnAndCancelNum" resultType="java.lang.Integer">
  246. SELECT IFNULL(SUM(a.actualReturnedNum + a.actualCancelNum), 0)
  247. FROM cm_returned_purchase_product a
  248. LEFT JOIN cm_returned_purchase b ON a.returnedID = b.id
  249. WHERE b.orderID = #{orderId}
  250. AND b.status = '2'
  251. AND b.delFlag = '0'
  252. </select>
  253. <select id="getServiceProviderId" resultType="java.lang.Integer">
  254. SELECT s.serviceProviderID
  255. FROM serviceprovider s
  256. LEFT JOIN USER u ON s.userID = u.userID
  257. WHERE s.unionId = #{unionId}
  258. AND u.validFlag = 1
  259. LIMIT 1
  260. </select>
  261. <select id="getClubUserIdBySpId" resultType="java.lang.Integer">
  262. SELECT userID
  263. FROM club
  264. WHERE spID = #{spId}
  265. </select>
  266. <select id="getReceiptBySmsMd5Code" resultType="com.caimei365.order.model.vo.ReceiptVo">
  267. SELECT DISTINCT cdr.id,
  268. cdr.payWay,
  269. cdr.payType,
  270. cdr.receiptType,
  271. cdr.receiptStatus,
  272. cdr.receiptAmount,
  273. cdr.smsContent,
  274. cdr.smsMd5Code,
  275. cdr.receiptDate,
  276. cdr.confirmDate,
  277. cdr.handlingFee,
  278. cdr.orderFlag,
  279. cdr.noOrderReason,
  280. cdr.reviewReason,
  281. IFNULL((
  282. SELECT SUM(b.associateAmount)
  283. FROM cm_receipt_order_relation b
  284. WHERE b.receiptID = cdr.id
  285. AND b.delFlag = '0'
  286. ), 0) AS associateAmount
  287. FROM cm_discern_receipt cdr
  288. LEFT JOIN cm_receipt_order_relation cror ON (cror.receiptID = cdr.id AND cror.delFlag = '0')
  289. WHERE cdr.smsMd5Code = #{smsMd5Code}
  290. AND cdr.delFlag = '0'
  291. </select>
  292. <select id="getReceiptList" resultType="com.caimei365.order.model.vo.ReceiptVo"
  293. parameterType="com.caimei365.order.model.bo.ReceiptParamsBo">
  294. SELECT DISTINCT
  295. cdr.id,
  296. cdr.payWay,
  297. cdr.payType,
  298. cdr.receiptType,
  299. cdr.receiptStatus,
  300. cdr.receiptAmount,
  301. cdr.smsContent,
  302. cdr.smsMd5Code,
  303. cdr.receiptDate,
  304. cdr.confirmDate,
  305. cdr.handlingFee,
  306. cdr.orderFlag,
  307. cdr.noOrderReason,
  308. cdr.reviewReason,
  309. cdr.newReceiptType,
  310. ifnull(coo.secondHandOrderFlag,0) as secondHandOrderFlag,
  311. CASE WHEN cror.relationType = 2 THEN co.organizeID
  312. WHEN cror.relationType = 1 THEN cso.organizeID
  313. ELSE '' END AS organizeId,
  314. CASE WHEN cror.relationType = 2 THEN co.userID
  315. WHEN cror.relationType = 1 THEN cso.userID
  316. ELSE '' END AS userId,
  317. IFNULL((
  318. SELECT SUM(b.associateAmount) FROM cm_receipt_order_relation b WHERE b.receiptID = cdr.id AND b.delFlag = '0'
  319. ), 0) AS associateAmount
  320. FROM cm_discern_receipt cdr
  321. LEFT JOIN cm_receipt_order_relation cror ON (cror.receiptID = cdr.id AND cror.delFlag = '0')
  322. LEFT JOIN cm_order co ON (cror.orderID = co.orderID AND cror.relationType = 2)
  323. LEFT JOIN cm_shop_order cso ON (cror.orderID = cso.shopOrderID AND cror.relationType = 1)
  324. LEFT JOIN cm_order coo ON coo.orderId=cso.orderId
  325. WHERE cdr.delFlag = '0'
  326. <if test="id != null and id != ''">
  327. AND cdr.id = #{id}
  328. </if>
  329. <if test="receiptType != null and receiptType != ''">
  330. AND cdr.receiptType = #{receiptType}
  331. </if>
  332. <if test="smsMd5Code != null and smsMd5Code != ''">
  333. AND cdr.smsMd5Code = #{smsMd5Code}
  334. </if>
  335. <if test="startDate != null and startDate != ''">
  336. AND cdr.receiptDate <![CDATA[ > ]]> #{startDate}
  337. </if>
  338. <if test="endDate != null and endDate != ''">
  339. AND cdr.receiptDate <![CDATA[ < ]]> #{endDate}
  340. </if>
  341. <if test="newReceiptType !=null and newReceiptType !=''">
  342. and cdr.newReceiptType=#{newReceiptType}
  343. </if>
  344. <if test="receiptStatusArr != null">
  345. AND cdr.receiptStatus in
  346. <foreach collection="receiptStatusArr" open="(" close=")" separator="," item="val">
  347. #{val}
  348. </foreach>
  349. </if>
  350. <if test="userIds != null and userIds.size() > 0">
  351. AND ((co.userID IN
  352. <foreach collection="userIds" open="(" close=")" separator="," item="val">
  353. #{val}
  354. </foreach>
  355. AND cror.relationType = 2 )
  356. OR (cso.userID IN
  357. <foreach collection="userIds" open="(" close=")" separator="," item="val">
  358. #{val}
  359. </foreach>
  360. AND cror.relationType = 1)
  361. OR cror.orderID IS NULL)
  362. </if>
  363. ORDER BY cdr.updateDate desc
  364. </select>
  365. <select id="getReceiptDetail" resultType="com.caimei365.order.model.vo.ReceiptVo">
  366. SELECT DISTINCT cdr.id,
  367. cdr.payWay,
  368. cdr.payType,
  369. cdr.receiptType,
  370. cdr.receiptStatus,
  371. cdr.receiptAmount,
  372. cdr.smsContent,
  373. cdr.smsMd5Code,
  374. cdr.receiptDate,
  375. cdr.confirmDate,
  376. cdr.reviewDate,
  377. cdr.cancelDate,
  378. cdr.handlingFee,
  379. cdr.orderFlag,
  380. cdr.noOrderReason,
  381. cdr.cancelReason,
  382. cdr.confirmType,
  383. cdr.reviewReason,
  384. IFNULL(cdr.newReceiptType, 2) AS newReceiptType,
  385. cdr.shopName,
  386. receiptUserPermissionID AS receiptUserPermissionId,
  387. confirmUserPermissionID AS confirmUserPermissionId,
  388. reviewUserPermissionID AS reviewUserPermissionId,
  389. cancelUserPermissionID AS cancelUserPermissionId,
  390. CASE
  391. WHEN cror.relationType = 2 THEN co.organizeID
  392. WHEN cror.relationType = 1 THEN cso.organizeID
  393. ELSE '' END AS organizeId,
  394. CASE
  395. WHEN cror.relationType = 2 THEN co.userID
  396. WHEN cror.relationType = 1 THEN cso.userID
  397. ELSE '' END AS userId,
  398. IFNULL((
  399. SELECT SUM(b.associateAmount)
  400. FROM cm_receipt_order_relation b
  401. WHERE b.receiptID = cdr.id
  402. AND b.delFlag = '0'
  403. ), 0) AS associateAmount
  404. FROM cm_discern_receipt cdr
  405. LEFT JOIN cm_receipt_order_relation cror ON (cror.receiptID = cdr.id AND cror.delFlag = '0')
  406. LEFT JOIN cm_order co ON (cror.orderID = co.orderID AND cror.relationType = 2)
  407. LEFT JOIN cm_shop_order cso ON (cror.orderID = cso.shopOrderID AND cror.relationType = 1)
  408. -- AND cror.relationType = 1
  409. WHERE cdr.delFlag = '0'
  410. AND cdr.id = #{id}
  411. </select>
  412. <select id="getReceiptOrders" resultType="com.caimei365.order.model.vo.OrderVo">
  413. SELECT IFNULL(o.orderSeen, 0) AS orderSeen,
  414. o.orderID AS orderId,
  415. o.shopOrderIds,
  416. o.orderSource,
  417. o.orderNo,
  418. o.userID AS userId,
  419. o.clubID AS clubId,
  420. o.organizeID AS organizeId,
  421. o.buyUserID AS buyUserId,
  422. o.orderTime AS orderTime,
  423. o.updateDate AS updateDate,
  424. o.delFlag,
  425. o.userBeans,
  426. o.orderType,
  427. o.orderSubmitType,
  428. o.confirmFlag,
  429. o.onlinePayFlag,
  430. o.splitFlag,
  431. o.payFlag,
  432. o.receiptStatus,
  433. o.payStatus,
  434. o.zeroCostFlag,
  435. o.sendOutStatus,
  436. o.refundType,
  437. o.affirmPaymentFlag,
  438. o.productCount,
  439. o.presentCount,
  440. o.promotionalGiftsCount,
  441. o.hasActProduct,
  442. o.promotionFullReduction,
  443. o.svipFullReduction,
  444. o.secondHandOrderFlag,
  445. o.invoiceFlag,
  446. o.freePostFlag AS postageFlag,
  447. o.freight AS postage,
  448. o.productTotalFee,
  449. o.orderTotalFee,
  450. o.payTotalFee,
  451. o.payableAmount,
  452. o.balancePayFee,
  453. o.discountFee,
  454. o.couponAmount,
  455. o.status,
  456. o.confirmTime,
  457. o.payTime,
  458. o.rebateFlag,
  459. o.clauseID AS clauseId,
  460. o.clauseName,
  461. IFNULL(u.userName, '') AS userName
  462. FROM cm_order o
  463. INNER JOIN cm_receipt_order_relation cror ON o.orderID = cror.orderID
  464. INNER JOIN cm_discern_receipt cdr ON cror.receiptID = cdr.id
  465. LEFT JOIN USER u ON o.userID = u.userID
  466. WHERE cdr.id = #{receiptId}
  467. AND o.delFlag = '0'
  468. AND cror.delFlag = '0'
  469. AND cdr.delFlag = '0'
  470. ORDER BY o.orderTime DESC
  471. </select>
  472. <select id="getReceiptOrderlist" resultType="com.caimei365.order.model.vo.OrderVo">
  473. SELECT IFNULL(o.orderSeen, 0) AS orderSeen,
  474. o.orderID AS orderId,
  475. o.shopOrderIds,
  476. o.orderSource,
  477. o.orderNo,
  478. o.userID AS userId,
  479. o.clubID AS clubId,
  480. o.organizeID AS organizeId,
  481. o.buyUserID AS buyUserId,
  482. o.orderTime AS orderTime,
  483. o.updateDate AS updateDate,
  484. o.delFlag,
  485. o.userBeans,
  486. o.orderType,
  487. o.orderSubmitType,
  488. o.confirmFlag,
  489. o.onlinePayFlag,
  490. o.splitFlag,
  491. o.payFlag,
  492. o.receiptStatus,
  493. o.payStatus,
  494. o.zeroCostFlag,
  495. o.sendOutStatus,
  496. o.refundType,
  497. o.affirmPaymentFlag,
  498. o.productCount,
  499. o.presentCount,
  500. o.promotionalGiftsCount,
  501. o.hasActProduct,
  502. o.promotionFullReduction,
  503. o.svipFullReduction,
  504. o.secondHandOrderFlag,
  505. o.invoiceFlag,
  506. o.freePostFlag AS postageFlag,
  507. o.freight AS postage,
  508. o.productTotalFee,
  509. o.orderTotalFee,
  510. o.payTotalFee,
  511. o.payableAmount,
  512. o.balancePayFee,
  513. o.discountFee,
  514. o.couponAmount,
  515. o.status,
  516. o.confirmTime,
  517. o.payTime,
  518. o.rebateFlag,
  519. o.clauseID AS clauseId,
  520. o.clauseName,
  521. IFNULL(u.userName, '') AS userName,
  522. cdr.newReceiptType,
  523. cdr.shopName
  524. FROM cm_shop_order cms
  525. INNER JOIN cm_order o ON cms.orderID = o.orderID
  526. INNER JOIN cm_discern_receipt cdr ON cms.shopOrderID = cdr.shopOrderID
  527. LEFT JOIN USER u ON o.userID = u.userID
  528. LEFT JOIN shop s ON s.shopID = cms.shopID
  529. WHERE cdr.id = #{receiptId}
  530. AND o.delFlag = '0'
  531. AND cms.delFlag = '0'
  532. AND cdr.delFlag = '0'
  533. ORDER BY o.orderTime DESC
  534. </select>
  535. <select id="getReceiptOrderlists" resultType="com.caimei365.order.model.vo.OrderVo">
  536. SELECT cdr.newReceiptType,
  537. cdr.shopName
  538. FROM cm_discern_receipt cdr
  539. LEFT JOIN shop s ON s.shopID = cdr.shopID
  540. WHERE cdr.id = #{receiptId}
  541. AND cdr.delFlag = '0'
  542. </select>
  543. <select id="getOrderListByParams" resultType="com.caimei365.order.model.vo.OrderVo">
  544. SELECT DISTINCT
  545. IFNULL(o.orderSeen,0) AS orderSeen,
  546. o.orderID AS orderId,
  547. o.shopOrderIds,
  548. o.orderSource,
  549. o.orderNo,
  550. o.userID AS userId,
  551. o.clubID AS clubId,
  552. o.organizeID AS organizeId,
  553. o.buyUserID AS buyUserId,
  554. o.orderTime AS orderTime,
  555. o.updateDate AS updateDate,
  556. o.delFlag,
  557. o.userBeans,
  558. o.orderType,
  559. o.orderSubmitType,
  560. o.confirmFlag,
  561. o.onlinePayFlag,
  562. o.splitFlag,
  563. o.payFlag,
  564. o.receiptStatus,
  565. o.payStatus,
  566. o.zeroCostFlag,
  567. o.sendOutStatus,
  568. o.refundType,
  569. o.affirmPaymentFlag,
  570. o.productCount,
  571. o.presentCount,
  572. o.promotionalGiftsCount,
  573. o.hasActProduct,
  574. o.promotionFullReduction,
  575. o.svipFullReduction,
  576. o.secondHandOrderFlag,
  577. o.invoiceFlag,
  578. o.freePostFlag AS postageFlag,
  579. o.freight AS postage,
  580. o.productTotalFee,
  581. o.orderTotalFee,
  582. o.payTotalFee,
  583. o.payableAmount,
  584. o.balancePayFee,
  585. o.discountFee,
  586. o.couponAmount,
  587. o.status,
  588. o.confirmTime,
  589. o.payTime,
  590. o.rebateFlag,
  591. o.clauseID AS clauseId,
  592. o.clauseName,
  593. <if test="organizeId == 0 or organizeId == null">
  594. IFNULL(u.userName, u.name) AS userName,
  595. </if>
  596. <if test="organizeId > 0">
  597. IFNULL(u.name, u.userName) AS userName,
  598. </if>
  599. '0' AS haveReturning,
  600. '0' AS haveReceipting
  601. FROM cm_order o
  602. LEFT JOIN user u ON o.userID = u.userID
  603. LEFT JOIN cm_order_product cop ON o.orderID = cop.orderID
  604. <where>
  605. <if test="excludeOrderId != null">
  606. AND o.orderID != #{excludeOrderId}
  607. </if>
  608. <if test="orderId != null">
  609. AND o.orderID = #{orderId}
  610. </if>
  611. AND o.delFlag = '0'
  612. AND o.organizeID = #{organizeId}
  613. AND o.receiptStatus IN
  614. <foreach collection="receiptStatusArr" open="(" close=")" item="receiptStatus" separator=",">
  615. #{receiptStatus}
  616. </foreach>
  617. AND o.status IN
  618. <foreach collection="orderStatusList" open="(" close=")" item="status" separator=",">
  619. #{status}
  620. </foreach>
  621. <if test="userIds != null and userIds.size() > 0">
  622. AND o.userID IN
  623. <foreach collection="userIds" open="(" close=")" separator="," item="val">
  624. #{val}
  625. </foreach>
  626. </if>
  627. <if test="userName != null and userName != ''">
  628. AND (u.userName LIKE CONCAT('%',#{userName},'%') OR u.name LIKE CONCAT('%',#{userName},'%'))
  629. </if>
  630. #不显示返佣,普通订单含返佣服务费显示
  631. AND o.rebateFlag != 1
  632. <if test="orderType == null or orderType == 0">
  633. AND cop.productID NOT IN(6060, 6061, 6062, 6063, 6064,6065, 6066, 6067, 6068, 6069)
  634. </if>
  635. <if test="orderType != null and orderType == 1">
  636. AND cop.productID IN(6060, 6061, 6062, 6063, 6064,6065, 6066, 6067, 6068, 6069)
  637. </if>
  638. </where>
  639. <if test="orderId != null and orderId != ''">
  640. ORDER BY (CASE WHEN o.orderID=#{orderId} THEN 1 ELSE 2 END),o.orderTime DESC
  641. </if>
  642. <if test="orderId == null or orderId == ''">
  643. ORDER BY o.orderTime DESC
  644. </if>
  645. </select>
  646. <select id="getOrderListByOrderIds" resultType="com.caimei365.order.model.vo.OrderVo">
  647. SELECT DISTINCT
  648. IFNULL(o.orderSeen,0) AS orderSeen,
  649. o.orderID AS orderId,
  650. o.shopOrderIds,
  651. o.orderSource,
  652. o.orderNo,
  653. o.userID AS userId,
  654. o.clubID AS clubId,
  655. o.organizeID AS organizeId,
  656. o.buyUserID AS buyUserId,
  657. o.orderTime AS orderTime,
  658. o.updateDate AS updateDate,
  659. o.delFlag,
  660. o.userBeans,
  661. o.orderType,
  662. o.orderSubmitType,
  663. o.confirmFlag,
  664. o.onlinePayFlag,
  665. o.splitFlag,
  666. o.payFlag,
  667. o.receiptStatus,
  668. o.payStatus,
  669. o.zeroCostFlag,
  670. o.sendOutStatus,
  671. o.refundType,
  672. o.affirmPaymentFlag,
  673. o.productCount,
  674. o.presentCount,
  675. o.promotionalGiftsCount,
  676. o.hasActProduct,
  677. o.promotionFullReduction,
  678. o.svipFullReduction,
  679. o.secondHandOrderFlag,
  680. o.invoiceFlag,
  681. o.freePostFlag AS postageFlag,
  682. o.freight AS postage,
  683. o.productTotalFee,
  684. o.orderTotalFee,
  685. o.payTotalFee,
  686. o.payableAmount,
  687. o.balancePayFee,
  688. o.discountFee,
  689. o.couponAmount,
  690. o.status,
  691. o.confirmTime,
  692. o.payTime,
  693. o.rebateFlag,
  694. o.clauseID AS clauseId,
  695. o.clauseName
  696. FROM cm_order o
  697. WHERE o.delFlag = '0' AND o.orderID IN
  698. <foreach collection="orderIdS" open="(" close=")" separator="," item="orderId">
  699. #{orderId}
  700. </foreach>
  701. order by o.payableAmount, o.orderID
  702. </select>
  703. <select id="countHaveReturning" resultType="java.lang.Integer">
  704. SELECT IFNULL(COUNT(id), 0)
  705. FROM cm_returned_purchase
  706. WHERE orderID = #{orderID}
  707. AND status = 1
  708. AND delFlag = 0
  709. </select>
  710. <select id="countHaveReceipting" resultType="java.lang.Integer">
  711. SELECT IFNULL(COUNT(cror.id), 0)
  712. FROM cm_receipt_order_relation cror
  713. INNER JOIN cm_discern_receipt cdr ON cror.receiptID = cdr.id
  714. WHERE cror.orderID = #{orderID}
  715. AND cror.delFlag = 0
  716. AND cdr.delFlag = 0
  717. AND cdr.receiptStatus = 2
  718. </select>
  719. <select id="getOnlineReceiptId" resultType="java.lang.Integer">
  720. SELECT cdr.id
  721. FROM cm_receipt_order_relation cror
  722. LEFT JOIN cm_discern_receipt cdr ON cror.receiptID = cdr.id
  723. WHERE cror.orderID = #{orderId}
  724. AND cror.relationType = '2'
  725. AND cror.delFlag = '0'
  726. AND cdr.delFlag = '0'
  727. AND cdr.receiptStatus = '3'
  728. AND cdr.payWay = '1'
  729. LIMIT 1
  730. </select>
  731. <select id="getRefundFeeByOrderId" resultType="com.caimei365.order.model.vo.ReturnedPurchaseVo">
  732. SELECT id,
  733. returnedPurchaseFee,
  734. refundFee
  735. FROM cm_returned_purchase
  736. WHERE orderID = #{orderId}
  737. AND STATUS = '2'
  738. </select>
  739. <select id="getShopOrderListByReceiptId" resultType="com.caimei365.order.model.vo.ShopOrderVo">
  740. SELECT DISTINCT cso.shopOrderId AS shopOrderId,
  741. cso.shopOrderNo,
  742. cso.orderID AS orderId,
  743. cso.orderNo,
  744. cso.shopID AS shopId,
  745. cso.note,
  746. cso.userID AS userId,
  747. cso.clubID AS clubId,
  748. cso.spID AS spId,
  749. cso.orderPromotionsId,
  750. cso.promotionFullReduction,
  751. cso.brokerage,
  752. cso.canRefundAmount,
  753. cso.itemCount,
  754. cso.totalAmount,
  755. cso.productAmount,
  756. cso.needPayAmount,
  757. cso.shopProductAmount,
  758. cso.shopPostFee,
  759. cso.shopTaxFee,
  760. cso.shouldPayShopAmount,
  761. cso.payedShopAmount,
  762. cso.orderTime,
  763. cso.orderSubmitType,
  764. cso.payStatus,
  765. cso.sendOutStatus,
  766. cso.splitFlag,
  767. cso.shopOtherFee,
  768. s.name AS shopName,
  769. ifnull(co.secondHandOrderFlag, 0) as secondHandOrderFlag,
  770. IFNULL((SELECT SUM(refundAmount)
  771. FROM cm_refund_shop_record
  772. WHERE shopOrderID = cso.shopOrderID
  773. AND delFlag = 0), 0) AS shopRefundAmount
  774. FROM cm_receipt_order_relation cror
  775. LEFT JOIN cm_shop_order cso ON cso.shopOrderID = cror.orderID
  776. LEFT JOIN shop s ON s.shopID = cso.shopID
  777. LEFT JOIN cm_order co on co.orderID = cso.orderID
  778. WHERE cror.delFlag = '0'
  779. AND cror.relationType = '1'
  780. AND cror.receiptID = #{receiptId}
  781. </select>
  782. <select id="getRefundShopOrders" resultType="com.caimei365.order.model.vo.ShopOrderVo">
  783. SELECT DISTINCT
  784. cso.shopOrderId AS shopOrderId,
  785. cso.shopOrderNo,
  786. cso.orderID AS orderId,
  787. cso.orderNo,
  788. cso.shopID AS shopId,
  789. cso.note,
  790. cso.userID AS userId,
  791. cso.clubID AS clubId,
  792. cso.spID AS spId,
  793. cso.orderPromotionsId,
  794. cso.promotionFullReduction,
  795. cso.brokerage,
  796. cso.canRefundAmount,
  797. cso.itemCount,
  798. cso.totalAmount,
  799. cso.productAmount,
  800. cso.needPayAmount,
  801. cso.shopProductAmount,
  802. cso.shopPostFee,
  803. cso.shopTaxFee,
  804. cso.shouldPayShopAmount,
  805. cso.payedShopAmount,
  806. cso.orderTime,
  807. cso.orderSubmitType,
  808. cso.payStatus,
  809. cso.sendOutStatus,
  810. cso.splitFlag,
  811. cso.shopOtherFee,
  812. s.name AS shopName,
  813. IFNULL((SELECT SUM(refundAmount) FROM cm_refund_shop_record WHERE shopOrderID = cso.shopOrderID AND delFlag =
  814. 0), 0) AS shopRefundAmount
  815. FROM cm_shop_order cso
  816. LEFT JOIN shop s ON s.shopID = cso.shopID
  817. LEFT JOIN cm_receipt_order_relation cror ON cso.shopOrderID = cror.orderID AND cror.relationType = 1
  818. LEFT JOIN cm_discern_receipt cdr ON cdr.id = cror.receiptID AND cdr.receiptType = 5 AND cdr.receiptStatus = 2
  819. LEFT JOIN user u ON u.userID = cso.userID
  820. WHERE cso.delFlag = 0
  821. AND (cror.delFlag = 0 OR cror.id IS NULL)
  822. <if test="orderId != null">
  823. AND cso.orderID = #{orderId}
  824. </if>
  825. <if test="shopName != null and shopName != ''">
  826. AND s.name LIKE CONCAT('%',#{shopName},'%')
  827. </if>
  828. <if test="userName != null and userName != ''">
  829. AND (u.userName LIKE CONCAT('%',#{userName},'%') OR u.name LIKE CONCAT('%',#{userName},'%') OR s.name LIKE
  830. CONCAT('%',#{userName},'%'))
  831. </if>
  832. <if test="confirmedType == 2">
  833. AND cdr.receiptStatus = 2
  834. </if>
  835. GROUP BY cso.shopOrderID
  836. <if test="confirmedType != 2">
  837. HAVING IFNULL(cso.payedShopAmount, 0) > IFNULL((SELECT SUM(refundAmount) FROM cm_refund_shop_record WHERE
  838. shopOrderID = cso.shopOrderID AND delFlag = 0), 0)
  839. </if>
  840. ORDER BY cso.orderTime DESC
  841. </select>
  842. <select id="getRebateShopOrders" resultType="com.caimei365.order.model.vo.ShopOrderVo">
  843. SELECT DISTINCT
  844. cso.shopOrderId AS shopOrderId,
  845. cso.shopOrderNo,
  846. cso.orderID AS orderId,
  847. cso.orderNo,
  848. cso.shopID AS shopId,
  849. cso.note,
  850. cso.userID AS userId,
  851. cso.clubID AS clubId,
  852. cso.spID AS spId,
  853. cso.orderPromotionsId,
  854. cso.promotionFullReduction,
  855. cso.brokerage,
  856. cso.canRefundAmount,
  857. cso.itemCount,
  858. cso.totalAmount,
  859. cso.productAmount,
  860. cso.needPayAmount,
  861. cso.shopProductAmount,
  862. cso.shopPostFee,
  863. cso.shopTaxFee,
  864. cso.shouldPayShopAmount,
  865. cso.payedShopAmount,
  866. cso.orderTime,
  867. cso.orderSubmitType,
  868. cso.payStatus,
  869. cso.sendOutStatus,
  870. cso.splitFlag,
  871. cso.shopOtherFee,
  872. s.name AS shopName,
  873. ifnull(co.secondHandOrderFlag,0) as secondHandOrderFlag,
  874. IF((SELECT (crpp.id) FROM cm_returned_purchase_product crpp LEFT JOIN cm_returned_purchase crp ON crp.id =
  875. crpp.returnedID
  876. WHERE crpp.shopOrderID = cso.shopOrderID AND crp.status = '1' AND crp.delFlag = 0 LIMIT 1) > 0, 1, 0) AS
  877. haveReturning
  878. FROM cm_shop_order cso
  879. LEFT JOIN shop s ON s.shopID = cso.shopID
  880. LEFT JOIN cm_order co ON co.orderID = cso.orderID
  881. <where>
  882. <if test="shopName != null and shopName != ''">
  883. AND s.name LIKE CONCAT('%', #{shopName}, '%')
  884. </if>
  885. AND cso.delFlag = '0'
  886. AND co.delFlag = '0'
  887. AND cso.shopOrderID NOT IN (
  888. SELECT DISTINCT cror.orderID FROM cm_receipt_order_relation cror LEFT JOIN cm_discern_receipt cdr ON
  889. cror.receiptID = cdr.id
  890. WHERE cror.delFlag = '0' AND cror.relationType = '1' AND cdr.receiptStatus = '2' AND cror.orderID IS NOT
  891. NULL
  892. )
  893. AND cso.orderID NOT IN (
  894. SELECT DISTINCT cror.orderID FROM cm_receipt_order_relation cror
  895. WHERE cror.delFlag = '0' AND cror.relationType = '2' AND cror.orderID IS NOT NULL
  896. )
  897. AND co.status != '0'
  898. AND co.receiptStatus != '3'
  899. AND co.rebateFlag = 1
  900. </where>
  901. ORDER BY cso.shopOrderID DESC
  902. </select>
  903. <select id="getShopOrderById" resultType="com.caimei365.order.model.vo.ShopOrderVo">
  904. SELECT shopOrderID AS shopOrderId,
  905. shopOrderNo,
  906. orderID AS orderId,
  907. orderNo,
  908. shopID AS shopId,
  909. note,
  910. userID AS userId,
  911. clubID AS clubId,
  912. spID AS spId,
  913. orderPromotionsId,
  914. promotionFullReduction,
  915. brokerage,
  916. canRefundAmount,
  917. itemCount,
  918. totalAmount,
  919. productAmount,
  920. needPayAmount,
  921. shopProductAmount,
  922. shopPostFee,
  923. shopTaxFee,
  924. shouldPayShopAmount,
  925. payedShopAmount,
  926. outStoreNum,
  927. IFNULL(presentNum, 0) AS presentNum,
  928. orderTime,
  929. orderSubmitType,
  930. payStatus,
  931. sendOutStatus,
  932. splitFlag
  933. FROM cm_shop_order
  934. WHERE shopOrderID = #{shopOrderId}
  935. AND delFlag = '0'
  936. </select>
  937. <select id="countAllPayAssociateAmount" resultType="java.lang.Double">
  938. SELECT IFNULL(SUM(cror.associateAmount), 0) FROM cm_receipt_order_relation cror
  939. LEFT JOIN cm_discern_receipt cdr on cror.receiptID = cdr.id
  940. WHERE cror.delFlag = '0' AND cdr.delFlag = '0' AND cdr.payWay != '3' AND cdr.receiptStatus in(2,3)
  941. <if test="orderID != null and orderID != ''">
  942. AND cror.orderID = #{orderId} AND cror.relationType = 2
  943. </if>
  944. </select>
  945. <select id="countNeedPayAmount" resultType="java.lang.Double">
  946. SELECT IFNULL(SUM(cso.needPayAmount), 0)
  947. FROM cm_receipt_order_relation cror
  948. LEFT JOIN cm_discern_receipt cdr ON cdr.id = cror.receiptID
  949. LEFT JOIN cm_shop_order cso ON cso.shopOrderID = cror.orderID
  950. WHERE cror.delFlag = '0'
  951. AND cror.relationType = '1'
  952. AND cdr.receiptType = 3
  953. AND cdr.delFlag = '0'
  954. AND cdr.receiptStatus = '2'
  955. AND cror.orderID IN (SELECT shopOrderID FROM cm_shop_order cso1 WHERE cso1.orderID = #{orderId})
  956. </select>
  957. <select id="getRebatePayTypeList" resultType="java.lang.Integer">
  958. SELECT cdr.payType
  959. FROM cm_receipt_order_relation cror
  960. LEFT JOIN cm_discern_receipt cdr ON cdr.id = cror.receiptID
  961. WHERE cror.relationType = '1'
  962. AND cror.delFlag = '0'
  963. AND cror.orderID = #{shopOrderId}
  964. and cdr.receiptType = '3'
  965. </select>
  966. <select id="getOpenidListByPermission" resultType="java.lang.String">
  967. SELECT DISTINCT wu.openid FROM wechat_user wu
  968. LEFT JOIN cm_receipt_user cru ON wu.unionId = cru.unionId
  969. LEFT JOIN cm_receipt_user_permission crup ON crup.user_id = cru.id
  970. WHERE crup.permission_id IN
  971. <foreach collection="permissions" open="(" close=")" item="permission" separator=",">
  972. #{permission}
  973. </foreach>
  974. AND cru.del_flag = 0
  975. </select>
  976. <select id="countAssociateAmountById" resultType="java.lang.Double">
  977. SELECT IFNULL(SUM(associateAmount), 0)
  978. FROM cm_receipt_order_relation
  979. WHERE receiptID = #{receiptId}
  980. </select>
  981. <select id="getRefundShopAmount" resultType="java.lang.Double">
  982. SELECT IFNULL(SUM(refundAmount), 0)
  983. FROM cm_refund_shop_record
  984. WHERE shopOrderID = #{shopOrderId}
  985. AND delFlag = 0
  986. </select>
  987. <select id="getShopIdByShopOrderId" resultType="java.lang.Integer">
  988. SELECT DISTINCT shopID
  989. FROM cm_shop_order
  990. WHERE shopOrderID = #{shopOrderId}
  991. </select>
  992. <select id="getSubShopOrderList" resultType="java.lang.Integer">
  993. SELECT cso2.shopOrderID
  994. FROM cm_shop_order cso1
  995. LEFT JOIN cm_order co ON co.orderID = cso1.orderID
  996. LEFT JOIN cm_shop_order cso2 ON cso2.orderID = co.orderID
  997. WHERE cso1.shopOrderID = #{shopOrderId}
  998. </select>
  999. <select id="getSubShopOrderRebate" resultType="java.lang.Integer">
  1000. SELECT cror.orderID FROM cm_receipt_order_relation cror
  1001. WHERE cror.delFlag = '0' AND cror.relationType = '1' AND cror.orderID IN
  1002. <foreach collection="shopOrderIdList" open="(" close=")" item="shopOrderId" separator=",">
  1003. #{shopOrderId}
  1004. </foreach>
  1005. AND cror.orderID IS NOT NULL
  1006. </select>
  1007. <insert id="insertRefundShop" keyColumn="id" keyProperty="id"
  1008. parameterType="com.caimei365.order.model.po.RefundShopPo" useGeneratedKeys="true">
  1009. INSERT INTO cm_refund_shop(shopID, operator, operatTime, refundAmount, refundType, remark, refundWay,
  1010. refundBalanceAmount)
  1011. VALUES (#{shopId}, #{operator}, #{operateTime}, #{refundAmount}, #{refundType}, #{remark}, #{refundWay},
  1012. #{refundBalanceAmount})
  1013. </insert>
  1014. <insert id="insertRefundShopRecord" keyColumn="id" keyProperty="id"
  1015. parameterType="com.caimei365.order.model.po.RefundShopRecordPo" useGeneratedKeys="true">
  1016. INSERT INTO cm_refund_shop_record(shopID, shopOrderID, shopOrderNo, refundAmount, refundType, refundTime,
  1017. refundShopID)
  1018. VALUES (#{shopId}, #{shopOrderId}, #{shopOrderNo}, #{refundAmount}, #{refundType}, #{refundTime},
  1019. #{refundShopId})
  1020. </insert>
  1021. <insert id="insertRebateRecord" keyColumn="id" keyProperty="id"
  1022. parameterType="com.caimei365.order.model.po.RebateRecordPo" useGeneratedKeys="true">
  1023. INSERT INTO cm_rebate_record(type, shopId, receiptID, shopOrderId, rebateAmount, operatTime)
  1024. VALUES (#{type}, #{shopId}, #{receiptId}, #{shopOrderId}, #{rebateAmount}, #{operateTime})
  1025. </insert>
  1026. <select id="getOrderReceiptRelationList" resultType="com.caimei365.order.model.po.OrderReceiptRelationPo">
  1027. SELECT cror.id,
  1028. cror.relationType,
  1029. cror.receiptId,
  1030. cror.associateAmount,
  1031. cror.orderId,
  1032. cror.delFlag,
  1033. cror.mbOrderId,
  1034. cror.orderRequestNo,
  1035. cror.splitStatus
  1036. FROM cm_receipt_order_relation cror
  1037. WHERE cror.receiptID = #{receiptId}
  1038. and cror.delflag = 0
  1039. ORDER BY cror.id DESC
  1040. </select>
  1041. <select id="getPendingAuditCount" resultType="java.lang.Integer">
  1042. SELECT COUNT(*)
  1043. FROM cm_receipt_order_relation cror
  1044. LEFT JOIN cm_discern_receipt cdr ON cror.receiptID = cdr.id
  1045. WHERE cror.orderID = #{orderId}
  1046. AND cror.relationType = '2'
  1047. AND cror.delFlag = '0'
  1048. AND cdr.delFlag = '0'
  1049. AND cdr.receiptStatus IN (2, 4)
  1050. </select>
  1051. <select id="ReceiptDetailVo" resultType="com.caimei365.order.model.vo.ShopOrderVo">
  1052. SELECT shopId,name AS shopName,linkMan,contractMobile FROM shop
  1053. <where>
  1054. <if test="keyWord!=null and keyWord!=''">
  1055. AND (name LIKE concat('%',#{keyWord},'%')
  1056. or linkMan LIKE CONCAT('%', #{keyWord}, '%'))
  1057. </if>
  1058. AND status = 90
  1059. </where>
  1060. </select>
  1061. <select id="ReceiptDetail" resultType="com.caimei365.order.model.vo.ShopOrderVo">
  1062. SELECT DISTINCT
  1063. cms.orderID,
  1064. cms.shopOrderID,
  1065. cms.shopOrderNo,
  1066. s.name AS shopName,
  1067. cms.productAmount,
  1068. cmo.orderNo,
  1069. u.userName,
  1070. cmo.confirmTime,
  1071. cms.receiptAmount,
  1072. cms.needPayAmount,
  1073. cms.payedShopAmount,
  1074. cmo.rebateFee
  1075. FROM cm_shop_order cms
  1076. LEFT JOIN shop s ON s.shopID = cms.shopID
  1077. LEFT JOIN cm_order cmo ON cmo.orderID = cms.orderID
  1078. LEFT JOIN `user` u ON u.userID = cms.userID
  1079. LEFT JOIN cm_discern_receipt csp ON csp.shopOrderID = cms.shopOrderID
  1080. <where>
  1081. <if test="keyWord !=null and keyWord !=''">
  1082. AND (s.name LIKE concat('%',#{keyWord},'%') or cmo.orderId=#{keyWord})
  1083. </if>
  1084. AND cms.payStatus=3
  1085. AND cmo.receiptStatus = 3
  1086. AND cmo.confirmTime >= '2021-09-01 00:01:00'
  1087. AND cmo.rebateFlag != 1
  1088. AND cms.shopId != 998
  1089. AND csp.newReceiptType is null
  1090. ORDER BY orderId DESC
  1091. </where>
  1092. </select>
  1093. <select id="ReceiptDetails" resultType="com.caimei365.order.model.vo.ShopOrderVo">
  1094. SELECT authUserId AS shopId,name AS shopName,linkMan,mobile as contractMobile FROM cm_brand_auth_user
  1095. <where>
  1096. <if test="keyWord!=null and keyWord !=''">
  1097. AND name LIKE concat('%',#{keyWord},'%')
  1098. or linkMan LIKE CONCAT('%', #{keyWord}, '%')
  1099. AND userIdentity = 2 AND status=1
  1100. </if>
  1101. AND userIdentity = 2 AND status=1
  1102. </where>
  1103. </select>
  1104. <select id="getTeamClubUserIdBySpId" resultType="java.lang.Integer">
  1105. SELECT userID
  1106. FROM club
  1107. WHERE spID IN (SELECT serviceId
  1108. FROM cm_serviceteam_group
  1109. WHERE teamId = (SELECT teamId FROM cm_serviceteam_group WHERE serviceId = #{spId}))
  1110. </select>
  1111. </mapper>