09异常订单.sql 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. -- Active: xiaoding_test@@192.168.110.85@3306@xiaoding_test
  2. /*
  3. 订单编号是order_exc_records表中的order_id字段,项目名称是order_exc_records表通过order_id关联order表查询出service_id项目编号再去关联project表查询出项目名称title,
  4. 用户名称是order_exc_records通过order_id关联order表查询出user_id再去和member_users表关联查询出用户名称nickname,
  5. 下单时间是order_exc_records表通过order_id关联到order_records表去通过判断该订单状态state然后获取created_at就是下单时间,
  6. 支付金额、支付方式是order_exc_records表中的order_id去 wallet_payment_records判断是否存在该订单存在则获取actual_amount实际支付金额字段和payment_method支付方式字段不存在则支付金额和支付方式空着即可,
  7. 服务状态是order_exc_records通过order_id和order_records关联获取state状态字段,
  8. 订单来源是order_exc_records表通过order_id关联到order表中的order_source字段,
  9. 技师/店铺的意思是该订单有可能是技师接单也有可能是店铺接单是通过订单来源类型进行区分的,
  10. 技师名称是根据order_exc_records表的order_id与order表关联查询出coach_id再与coach_users表关联查询出user_id再与用户表关联查询出技师名称,
  11. 店铺名称是order_exc_records表通过order_id关联到order表中的shop_id再与shop_auth_records表查询出shop_name,
  12. 技师/店铺接单时间是order_exc_records表通过order_id去order_records表判断该订单编号是否存在,
  13. 存在则再去通过state判断下单状态得出created_at下单时间,如果不存在则空着即可,
  14. 区域是order_exc_records表通过order_id关联的order表中的area_code字段,地址是order_exc_records表通过order_id关联的order表中的address字段,
  15. 备注是order_exc_records表通过order_id关联的order表中的remark字段,订单来源是order_exc_records表通过order_id关联的order表中的order_source字段
  16. 补充逻辑:用户表是member_users表,技师表是coach_users表,店铺表是shop_auth_records表
  17. 不查询字段:跟单客服是系统表获取的
  18. */
  19. DROP TABLE IF EXISTS report_order_exception;
  20. CREATE TABLE report_order_exception AS
  21. SELECT
  22. oer.order_id as order_id /* 订单编号 */,
  23. p.title as project_title /* 项目名称 */,
  24. mu.nickname as user_name /* 用户名称 */,
  25. orr.created_at as order_time /* 下单时间 */,
  26. wpr.actual_amount as payment_amount /* 支付金额 */,
  27. wpr.payment_method as payment_method /* 支付方式 */,
  28. orr.state as service_state /* 服务状态 */,
  29. CASE
  30. WHEN o.order_source = 'coach' THEN u_coach.nickname /* 技师昵称 */
  31. WHEN o.order_source = 'shop' THEN sar.shop_name /* 店铺名称 */
  32. ELSE NULL
  33. END as accept_name /* 技师/店铺 */,
  34. orr.created_at as accept_time /* 技师/店铺接单时间 */,
  35. o.area_code as area_code /* 区域 */,
  36. o.address as address /* 地址 */,
  37. o.remark as remark /* 备注 */,
  38. o.order_source as order_source /* 订单来源 */
  39. FROM
  40. order_exc_records oer
  41. LEFT JOIN
  42. order_records orr ON oer.order_id = orr.order_id /* 关联订单记录表 */
  43. LEFT JOIN
  44. `order` o ON oer.order_id = o.id /* 关联订单表 */
  45. LEFT JOIN
  46. project p ON o.service_id = p.id /* 关联项目表 */
  47. LEFT JOIN
  48. member_users mu ON o.user_id = mu.id /* 关联用户表 */
  49. LEFT JOIN
  50. wallet_payment_records wpr ON oer.order_id = wpr.order_id /* 关联支付记录表 */
  51. LEFT JOIN
  52. coach_users cu ON o.coach_id = cu.id /* 关联技师用户表 */
  53. LEFT JOIN
  54. member_users u_coach ON cu.user_id = u_coach.id /* 关联用户表获取技师昵称 */
  55. LEFT JOIN
  56. shop_auth_records sar ON o.shop_id = sar.id /* 关联店铺认证记录表 */
  57. WHERE
  58. orr.state IS NOT NULL /* 确保订单状态存在 */