12店铺应急订单统计.sql 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. -- Active: xiaoding_test@@192.168.110.85@3306@xiaoding_test
  2. /*
  3. 您是一位专业的dba,同时会业务分析。请参考以上数据库的设计文档,给我写一个sql,关联查询出:xxx字段
  4. AI一般会出现的问题 用户表是member_users表 技师名称最终实在用户表找到的
  5. 店铺名称是order表通过shop_id关联shop_auth_records表并判断shop_id是否存在存在则获取shop_name字段为店铺名称不存在则空着即可,
  6. 项目名称是order表的service_id关联shop_services表并判断service_id是否存在,存在则获取name字段为项目名称不存在则空着即可,
  7. 下单时间是order表id关联order_records表并判断state字段的状态为用户下单获取created_at字段为下单时间,
  8. 下单金额是order表中total_amount字段,技师名称是order表通过coach_id关联coach_users表并获取到user_id再通过user_id去关联member_users表获取nickname字段做为技师名称,
  9. 到达时间是order表id关联order_records表并state状态为已到达获取created_at字段为到达时间,区域是order表中的area_code字段,
  10. 位置是order表中的address字段,店铺联系电话是order表通过shop_id关联shop_auth_records表并判断shop_id是否存在,
  11. 存在则获取contact_phone字段为店铺联系电话不存在则空着即可,
  12. 技师联系方式是order表coach_id关联coach_users表获取到的user_id再通过user_id关联member_users表获取mobile字段做为技师联系方式,
  13. 距离是order表中distance字段,平台收入是order表通过id关联wallet_split_records并判断订单编号是否存在,
  14. 存在则通过判断split_type分账类型去获取对应的split_amount分账金额字段做为平台收入
  15. */
  16. /*
  17. 查询订单相关信息包括:
  18. 店铺名称、项目名称、下单时间、下单金额、技师名称、到达时间、区域、位置、
  19. 店铺联系电话、技师联系方式、距离、平台收入
  20. */
  21. WITH order_times AS (
  22. SELECT
  23. order_id,
  24. MAX(CASE WHEN state = 'USER_SUBMIT' THEN created_at END) AS submit_time /* 下单时间 */,
  25. MAX(CASE WHEN state = 'COACH_ARRIVED' THEN created_at END) AS arrive_time /* 到达时间 */
  26. FROM order_records
  27. WHERE state IN ('USER_SUBMIT', 'COACH_ARRIVED')
  28. GROUP BY order_id
  29. )
  30. SELECT
  31. ord.id /* 订单编号 */,
  32. COALESCE(sar.shop_name, '') /* 店铺名称 */,
  33. COALESCE(ss.name, '') /* 项目名称 */,
  34. ot.submit_time /* 下单时间 */,
  35. ord.total_amount /* 下单金额 */,
  36. COALESCE(mu.nickname, '') /* 技师名称 */,
  37. ot.arrive_time /* 到达时间 */,
  38. ord.area_code /* 区域 */,
  39. ord.address /* 位置 */,
  40. COALESCE(sar.contact_phone, '') /* 店铺联系电话 */,
  41. COALESCE(mu.mobile, '') /* 技师联系方式 */,
  42. ord.distance /* 距离 */,
  43. COALESCE(wsr.split_amount, 0.00) /* 平台收入 */
  44. FROM `order` ord /* 使用反引号避免关键字冲突,使用别名ord */
  45. LEFT JOIN shop_auth_records sar ON ord.shop_id = sar.shop_id /* 关联店铺认证信息 */
  46. LEFT JOIN shop_services ss ON ord.service_id = ss.id /* 关联店铺服务 */
  47. LEFT JOIN order_times ot ON ord.id = ot.order_id /* 关联订单时间 */
  48. LEFT JOIN coach_users cu ON ord.coach_id = cu.id /* 关联技师用户 */
  49. LEFT JOIN member_users mu ON cu.user_id = mu.id /* 关联会员用户 */
  50. LEFT JOIN wallet_split_records wsr ON ord.id = wsr.order_id
  51. AND wsr.split_type = 'PLATFORM_SHARE' /* 关联钱包分账记录-平台分成 */
  52. WHERE 1=1
  53. /* 这里可以添加其他筛选条件,如时间范围、订单状态等 */
  54. ORDER BY ord.id DESC /* 按订单编号倒序排序 */