08订单管理.sql 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. -- Active: xiaoding_test@@192.168.110.85@3306@xiaoding_test
  2. /*
  3. * 订单详情统计查询
  4. */
  5. /*
  6. 订单编号是order表的id,项目名称是order表通过service_id与project表关联查询出项目名称title,
  7. 用户名称是order表通过user_id和member_users表关联查询出用户姓名nickname,
  8. 下单时间是order表的中的created_at,支付金额、支付方式是order表的id与 wallet_payment_records表的order_id关联查询出,
  9. 技师/店铺的意思是该订单有可能是技师接单也有可能是店铺接单是通过订单来源类型进行区分的,区域是order表的area_code,
  10. 地址是order表的address,备注是order表的remark,订单来源是order表的order_source,路费是order表的路程金额,
  11. 服务状态是order表通过id与order_records表关联查询state,技师/店铺接单时间以及到达时间、开始服务时间都是从order_records表中的created_at字段,
  12. 技师减免是order表通过coach_id和project_id与coach_project关联通过判断找出该discount_amount字段,
  13. 店铺优惠劵和平台优惠劵是order表中id与market_coupon_records表判断是否存在该订单编号存在然后通过优惠卷编号与market_coupons表关联获取优惠劵金额,
  14. 订单类型是order表order_type字段,上级订单是因为客户在原有订单基础上再次下单从而产生的关联原有订单,
  15. 上级订单项目是因为客户在原有订单基础上再次下单从而产生的关联原有订单项目名称,
  16. 用户确认撤离时间、技师确认离开时间都是从order_records表中的created_at字段。
  17. 补充逻辑:技师名称是根据order表的coach_is与coach_users关联查询出user_id再与用户表关联查询出技师名称
  18. 先不要了没设计: 营销类型 砍价减免金额 打赏金额 悬赏金额 跟单客服是系统表里的
  19. */
  20. WITH
  21. order_status AS (
  22. SELECT
  23. order_id,
  24. state /* 状态 */,
  25. created_at /* 状态变更时间 */,
  26. ROW_NUMBER() OVER (
  27. PARTITION BY
  28. order_id,
  29. state
  30. ORDER BY created_at
  31. ) AS rn
  32. FROM order_records
  33. )
  34. SELECT
  35. o.id /* 订单编号 */,
  36. p.title /* 项目名称 */,
  37. mu.nickname /* 用户名称 */,
  38. o.created_at /* 下单时间 */,
  39. o.total_amount /* 支付金额 */,
  40. os_state.state /* 服务状态 */,
  41. CASE o.order_source
  42. WHEN 'PLATFORM' THEN CONCAT('技师-', coach_mu.nickname)
  43. ELSE CONCAT('店铺-', sa.shop_name)
  44. END /* 技师/店铺 */,
  45. os_accept.created_at /* 技师/店铺接单时间 */,
  46. o.area_code /* 区域 */,
  47. o.address /* 地址 */,
  48. o.remark /* 备注 */,
  49. o.order_source /* 订单来源 */,
  50. os_arrive.created_at /* 到达时间 */,
  51. TIMESTAMPDIFF(
  52. MINUTE,
  53. NOW(),
  54. os_arrive.created_at
  55. ) /* 订单倒计时 */,
  56. os_start.created_at /* 服务开始时间 */,
  57. mc_platform.discount_value /* 平台优惠券 */,
  58. cp.discount_amount /* 技师减免 */,
  59. mc_shop.discount_value /* 商铺代金券 */,
  60. wpr.payment_method /* 支付方式 */,
  61. o.traffic_amount /* 路费 */,
  62. o.order_type /* 订单类型 */,
  63. os_user_leave.created_at /* 用户确认撤离时间 */,
  64. os_coach_leave.created_at /* 技师确认离开时间 */
  65. FROM
  66. `order` o
  67. LEFT JOIN project p ON o.service_id = p.id /* 关联项目表 */
  68. LEFT JOIN member_users mu ON o.user_id = mu.id /* 关联用户表 */
  69. /* 关联技师表和用户表获取技师名称 */
  70. LEFT JOIN coach_users cu ON o.coach_id = cu.id /* 关联技师表 */
  71. LEFT JOIN member_users coach_mu ON cu.user_id = coach_mu.id /* 关联用户表获取技师名称 */
  72. LEFT JOIN shop_auth_records sa ON o.shop_id = sa.shop_id /* 关联店铺认证表 */
  73. LEFT JOIN coach_project cp ON o.coach_id = cp.coach_id
  74. AND o.service_id = cp.project_id /* 关联技师项目表 */
  75. LEFT JOIN wallet_payment_records wpr ON o.id = wpr.order_id /* 关联支付记录表 */
  76. /* 关联优惠券记录和优惠券表-平台券 */
  77. LEFT JOIN market_coupon_records mcr_p ON o.id = mcr_p.order_id
  78. LEFT JOIN market_coupons mc_platform ON mcr_p.coupon_id = mc_platform.id
  79. AND mc_platform.coupon_type = 'PLATFORM'
  80. /* 关联优惠券记录和优惠券表-店铺券 */
  81. LEFT JOIN market_coupon_records mcr_s ON o.id = mcr_s.order_id
  82. LEFT JOIN market_coupons mc_shop ON mcr_s.coupon_id = mc_shop.id
  83. AND mc_shop.coupon_type = 'SHOP'
  84. /* 关联订单状态-当前状态 */
  85. LEFT JOIN order_status os_state ON o.id = os_state.order_id
  86. AND os_state.rn = 1
  87. /* 关联订单状态-接单时间 */
  88. LEFT JOIN order_status os_accept ON o.id = os_accept.order_id
  89. AND os_accept.state = 'ACCEPTED'
  90. AND os_accept.rn = 1
  91. /* 关联订单状态-到达时间 */
  92. LEFT JOIN order_status os_arrive ON o.id = os_arrive.order_id
  93. AND os_arrive.state = 'ARRIVED'
  94. AND os_arrive.rn = 1
  95. /* 关联订单状态-开始服务时间 */
  96. LEFT JOIN order_status os_start ON o.id = os_start.order_id
  97. AND os_start.state = 'STARTED'
  98. AND os_start.rn = 1
  99. /* 关联订单状态-用户确认撤离时间 */
  100. LEFT JOIN order_status os_user_leave ON o.id = os_user_leave.order_id
  101. AND os_user_leave.state = 'USER_CONFIRMED_LEAVE'
  102. AND os_user_leave.rn = 1
  103. /* 关联订单状态-技师确认离开时间 */
  104. LEFT JOIN order_status os_coach_leave ON o.id = os_coach_leave.order_id
  105. AND os_coach_leave.state = 'COACH_CONFIRMED_LEAVE'
  106. AND os_coach_leave.rn = 1
  107. WHERE
  108. o.deleted_at IS NULL
  109. ORDER BY o.created_at DESC;