10报警订单.sql 4.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. -- Active: xiaoding_test@@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表查询出的project_id通过order表的project_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. /* 报警订单视图 */
  22. DROP VIEW IF EXISTS manage_alarm_order;
  23. CREATE OR REPLACE VIEW manage_alarm_order AS
  24. WITH
  25. order_create_time AS (
  26. /* 获取下单时间 */
  27. SELECT order_id, created_at
  28. FROM order_records ord1
  29. WHERE
  30. state = '接单状态' /* 请替换为实际的接单状态值 */
  31. AND created_at = (
  32. SELECT MIN(created_at)
  33. FROM order_records ord2
  34. WHERE
  35. ord1.order_id = ord2.order_id
  36. AND state = '接单状态'
  37. )
  38. ),
  39. coach_accept_time AS (
  40. /* 获取技师接单时间 */
  41. SELECT order_id, created_at
  42. FROM order_records ord1
  43. WHERE
  44. state = '技师接单状态' /* 请替换为实际的技师接单状态值 */
  45. AND created_at = (
  46. SELECT MIN(created_at)
  47. FROM order_records ord2
  48. WHERE
  49. ord1.order_id = ord2.order_id
  50. AND state = '技师接单状态'
  51. )
  52. )
  53. SELECT
  54. ca.order_id AS order_id /* 序号 */,
  55. t1.order_no AS order_no /* 订单号 */,
  56. p.title AS project_name /* 项目名称 */,
  57. mu1.nickname AS user_name /* 用户名称 */,
  58. OCT.created_at AS order_time /* 下单时间 */,
  59. wpr.actual_amount AS payment_amount /* 支付金额 */,
  60. orr.state AS service_state /* 服务状态 */,
  61. mu2.nickname AS coach_name /* 技师昵称 */,
  62. cat.created_at AS coach_accept_time /* 技师接单时间 */,
  63. t1.area_code AS area_code /* 区域 */,
  64. t1.address AS address /* 地址 */,
  65. t1.remark AS remark /* 备注 */,
  66. mu3.nickname AS agent_name /* 代理商 */,
  67. mu3.mobile AS agent_mobile /* 代理商电话 */
  68. FROM
  69. coach_alerts ca
  70. LEFT JOIN `order` t1 ON ca.order_id = t1.id
  71. LEFT JOIN project p ON t1.project_id = p.id
  72. LEFT JOIN member_users mu1 ON t1.user_id = mu1.id
  73. LEFT JOIN order_create_time OCT ON ca.order_id = OCT.order_id
  74. LEFT JOIN wallet_payment_records wpr ON ca.order_id = wpr.order_id
  75. LEFT JOIN order_records orr ON ca.order_id = orr.order_id
  76. LEFT JOIN coach_users cu ON t1.coach_id = cu.id
  77. LEFT JOIN member_users mu2 ON cu.user_id = mu2.id
  78. LEFT JOIN coach_accept_time cat ON ca.order_id = cat.order_id
  79. LEFT JOIN agent_infos ai ON t1.agent_id = ai.id
  80. LEFT JOIN member_users mu3 ON ai.user_id = mu3.id
  81. WHERE
  82. orr.created_at = (
  83. /* 获取最新状态记录 */
  84. SELECT MAX(created_at)
  85. FROM order_records
  86. WHERE
  87. order_id = ca.order_id
  88. )
  89. ORDER BY ca.order_id DESC;
  90. SELECT * FROM manage_alarm_order;