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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  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. DROP TABLE IF EXISTS report_shop_emergency_order;
  22. CREATE TABLE report_shop_emergency_order AS
  23. WITH order_times AS (
  24. SELECT
  25. order_id,
  26. MAX(CASE WHEN state = 'USER_SUBMIT' THEN created_at END) AS submit_time /* 下单时间 */,
  27. MAX(CASE WHEN state = 'COACH_ARRIVED' THEN created_at END) AS arrive_time /* 到达时间 */
  28. FROM order_records
  29. WHERE state IN ('USER_SUBMIT', 'COACH_ARRIVED')
  30. GROUP BY order_id
  31. )
  32. SELECT
  33. ord.id as order_id /* 订单编号 */,
  34. COALESCE(sar.shop_name, '') as shop_name /* 店铺名称 */,
  35. COALESCE(ss.name, '') as service_name /* 项目名称 */,
  36. ot.submit_time as submit_time /* 下单时间 */,
  37. ord.total_amount as total_amount /* 下单金额 */,
  38. COALESCE(mu.nickname, '') as coach_name /* 技师名称 */,
  39. ot.arrive_time as arrive_time /* 到达时间 */,
  40. ord.area_code as area_code /* 区域 */,
  41. ord.address as address /* 位置 */,
  42. COALESCE(sar.contact_phone, '') as shop_phone /* 店铺联系电话 */,
  43. COALESCE(mu.mobile, '') as coach_phone /* 技师联系方式 */,
  44. ord.distance as distance /* 距离 */,
  45. COALESCE(wsr.split_amount, 0.00) as platform_income /* 平台收入 */
  46. FROM `order` ord /* 使用反引号避免关键字冲突,使用别名ord */
  47. LEFT JOIN shop_auth_records sar ON ord.shop_id = sar.shop_id /* 关联店铺认证信息 */
  48. LEFT JOIN shop_services ss ON ord.service_id = ss.id /* 关联店铺服务 */
  49. LEFT JOIN order_times ot ON ord.id = ot.order_id /* 关联订单时间 */
  50. LEFT JOIN coach_users cu ON ord.coach_id = cu.id /* 关联技师用户 */
  51. LEFT JOIN member_users mu ON cu.user_id = mu.id /* 关联会员用户 */
  52. LEFT JOIN wallet_split_records wsr ON ord.id = wsr.order_id
  53. AND wsr.split_type = 'PLATFORM_SHARE' /* 关联钱包分账记录-平台分成 */
  54. WHERE 1=1
  55. /* 这里可以添加其他筛选条件,如时间范围、订单状态等 */
  56. ORDER BY ord.id DESC /* 按订单编号倒序排序 */