10报警订单.sql 4.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. -- Active: 1732070527111@@192.168.110.85@3306@xiaoding_test
  2. /*
  3. 订单编号是coach_alerts表的order_id,用户名称是coach_alerts表通过order_id关联order表查询出的user_id通过order表的user_id关联member_users表查询出nickname为用户名称,
  4. 项目名称是coach_alerts表通过order_id关联order表查询出的service_id通过order表的service_id关联project表查询出title为项目名称,
  5. 下单时间是coach_alerts表通过order_id关联的order_records表经过判断order_id是否存在以及state状态是否是接单状态最后都满足则获取order_records表的created_at字段为下单时间,
  6. 支付金额是coach_alerts表通过order_id直接与wallet_payment_records表关联判断订单编号是否存在,存在则获取wallet_payment_records表的actual_amount为支付金额,
  7. 服务状态是coach_alerts表通过order_id关联的order_records表经过判断order_id是否存在以及state最新状态,
  8. 技师昵称是coach_alerts表通过order_id关联order表查询出的coach_id通过order表的coach_id关联coach_users表查询出user_id然后再去关联member_users表查询出nickname为技师名称,
  9. 技师接单时间是coach_alerts表通过order_id关联的order_records表经过判断order_id是否存在以及state状态是否是技师接单状态最后都满足则获取order_records表的created_at字段为技师接单时间,
  10. 区域是coach_alerts表的order_id关联的order表中的area_code字段,
  11. 地址是coach_alerts表的order_id关联的order表中的address字段,
  12. 备注是coach_alerts表的order_id关联的order表中的remark字段,
  13. 代理商是coach_alerts表的order_id关联的order表获取agent_id再去关联agent_infos表获取user_id再去关联member_users表中的nickname字段为代理商,
  14. 代理商电话是coach_alerts表的order_id关联的order表获取agent_id再去关联agent_infos表获取user_id再去关联member_users表中的mobile字段为代理商电话
  15. 查询不出的字段:跟单客服是系统表的
  16. 没设计的字段:附近站点电话、负责人电话
  17. */
  18. /*
  19. 查询订单编号、项目名称、用户名称、下单时间、支付金额、服务状态、技师、技师接单时间、区域、地址、备注、代理商、代理商电话
  20. */
  21. DROP TABLE IF EXISTS report_alarm_order;
  22. CREATE TABLE report_alarm_order AS
  23. WITH order_create_time AS (
  24. /* 获取下单时间 */
  25. SELECT
  26. order_id,
  27. created_at
  28. FROM order_records ord1
  29. WHERE state = '接单状态' /* 请替换为实际的接单状态值 */
  30. AND created_at = (
  31. SELECT MIN(created_at)
  32. FROM order_records ord2
  33. WHERE ord1.order_id = ord2.order_id
  34. AND state = '接单状态'
  35. )
  36. ),
  37. coach_accept_time AS (
  38. /* 获取技师接单时间 */
  39. SELECT
  40. order_id,
  41. created_at
  42. FROM order_records ord1
  43. WHERE state = '技师接单状态' /* 请替换为实际的技师接单状态值 */
  44. AND created_at = (
  45. SELECT MIN(created_at)
  46. FROM order_records ord2
  47. WHERE ord1.order_id = ord2.order_id
  48. AND state = '技师接单状态'
  49. )
  50. )
  51. SELECT
  52. ca.order_id as order_id /* 订单编号 */,
  53. p.title as project_title /* 项目名称 */,
  54. mu1.nickname as user_name /* 用户名称 */,
  55. oct.created_at as order_time /* 下单时间 */,
  56. wpr.actual_amount as payment_amount /* 支付金额 */,
  57. orr.state as service_state /* 服务状态 */,
  58. mu2.nickname as coach_name /* 技师昵称 */,
  59. cat.created_at as coach_accept_time /* 技师接单时间 */,
  60. t1.area_code as area_code /* 区域 */,
  61. t1.address as address /* 地址 */,
  62. t1.remark as remark /* 备注 */,
  63. mu3.nickname as agent_name /* 代理商 */,
  64. mu3.mobile as agent_mobile /* 代理商电话 */
  65. FROM coach_alerts ca
  66. LEFT JOIN `order` t1 ON ca.order_id = t1.id
  67. LEFT JOIN project p ON t1.service_id = p.id
  68. LEFT JOIN member_users mu1 ON t1.user_id = mu1.id
  69. LEFT JOIN order_create_time oct ON ca.order_id = oct.order_id
  70. LEFT JOIN wallet_payment_records wpr ON ca.order_id = wpr.order_id
  71. LEFT JOIN order_records orr ON ca.order_id = orr.order_id
  72. LEFT JOIN coach_users cu ON t1.coach_id = cu.id
  73. LEFT JOIN member_users mu2 ON cu.user_id = mu2.id
  74. LEFT JOIN coach_accept_time cat ON ca.order_id = cat.order_id
  75. LEFT JOIN agent_infos ai ON t1.agent_id = ai.id
  76. LEFT JOIN member_users mu3 ON ai.user_id = mu3.id
  77. WHERE orr.created_at = (
  78. /* 获取最新状态记录 */
  79. SELECT MAX(created_at)
  80. FROM order_records
  81. WHERE order_id = ca.order_id
  82. )
  83. ORDER BY ca.order_id DESC;