02技师列表.sql 3.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. -- Active: xiaoding_test@@192.168.110.85@3306
  2. /*
  3. 这段sql语句是根据"market_dist_teams"表获取的,这个表的解释是:
  4. 1、当一个用户A邀请另一个用户B的时候,数据是这样的
  5. - object_id是A的id
  6. - object_type是A的用户类型
  7. - user_id是B的id
  8. - 统计的时候A是B的一级邀请人
  9. 2、当用户B邀请C的时候,数据是这样的
  10. - object_id是B的id
  11. - object_type是B的用户类型
  12. - user_id是C的id
  13. - 统计的时候B是C的一级邀请人
  14. - 统计的时候A是C的二级邀请人
  15. 请重写我的统计sql
  16. */
  17. /*新的技师管理视图*/
  18. DROP VIEW IF EXISTS v_coach_list;
  19. CREATE OR REPLACE VIEW v_coach_list AS
  20. SELECT
  21. cu.id AS id,/*技师id*/
  22. ci.nickname AS nickname,/*技师名称*/
  23. ci.mobile AS mobile,/*手机号码*/
  24. ci.avatar AS avatar,/*头像*/
  25. ci.gender AS gender,/*性别*/
  26. ci.birthday AS birthday,/*生日*/
  27. cu.created_at AS created_at,/*注册时间*/
  28. cu.state AS state,/*技师状态*/
  29. cu.invite_code AS invite_code,/*邀请码*/
  30. cu.qr_code AS qr_code,/*二维码*/
  31. cu.is_vip AS is_vip, /*是否开通会员*/
  32. cu.vip_time AS vip_time,/*开通会员时间*/
  33. cu.level AS level,/*技师等级*/
  34. cu.score AS score,/*技师评分*/
  35. cu.work_status AS work_status,/*工作状态*/
  36. cu.formal_photo AS formal_photo,/*正式照*/
  37. cu.virtual_order AS virtual_order,/*虚拟订单*/
  38. /* 认证信息 */
  39. crr.id_card AS id_card,/*身份证*/
  40. crr.real_name AS real_name,/*真实姓名*/
  41. crr.id_card_front_photo AS id_card_front_photo,/*身份证正面*/
  42. crr.id_card_back_photo AS id_card_back_photo,/*身份证反面*/
  43. cq.health_cert AS health_cert,/*健康证*/
  44. cq.qual_photo AS qual_photo,/*资格证*/
  45. cq.business_license AS business_license,/*营业执照*/
  46. /* 所属店铺 */
  47. sar.shop_name AS shop_name,/*店铺名称*/
  48. /* 当前位置信息 */
  49. cl.city AS city,/*城市*/
  50. cl.address AS address,/*当前位置*/
  51. /* 钱包余额 */
  52. COALESCE(cw.total_income, 0) AS total_income,/*总收入*/
  53. COALESCE(cw.total_expense, 0) AS total_expense,/*总支出*/
  54. COALESCE(cw.total_balance, 0) AS total_balance,/*钱包余额*/
  55. COALESCE(cw.available_balance, 0) AS available_balance,/*可用余额*/
  56. COALESCE(cw.frozen_amount, 0) AS frozen_amount,/*冻结余额*/
  57. /* 一级邀请人 */
  58. CASE
  59. WHEN mdt1.object_type = 'App\\Models\\CoachUser' THEN ci1.nickname
  60. WHEN mdt1.object_type = 'App\\Models\\MemberUser' THEN mu1.nickname
  61. END AS inviter_level1_name,
  62. /* 二级邀请人 */
  63. CASE
  64. WHEN mdt2.object_type = 'App\\Models\\CoachUser' THEN ci2.nickname
  65. WHEN mdt2.object_type = 'App\\Models\\MemberUser' THEN mu2.nickname
  66. END AS inviter_level2_name
  67. FROM coach_users cu
  68. LEFT JOIN coach_info_records ci ON cu.info_record_id = ci.id
  69. LEFT JOIN coach_locations cl ON cu.id = cl.coach_id AND cl.type = 2
  70. LEFT JOIN coach_qual_records cq ON cu.qualification_record_id = cq.id
  71. LEFT JOIN shop_auth_records sar ON cu.shop_id = sar.shop_id
  72. LEFT JOIN coach_real_records crr ON cu.real_auth_record_id = crr.id
  73. LEFT JOIN wallet cw ON cu.id = cw.owner_id AND cw.owner_type = 'App\\Models\\CoachUser'
  74. /* 一级邀请人关联 */
  75. LEFT JOIN market_dist_teams mdt1 ON cu.id = mdt1.user_id AND mdt1.level = 1
  76. LEFT JOIN coach_info_records ci1 ON mdt1.object_type = 'App\\Models\\CoachUser' AND mdt1.object_id = ci1.coach_id
  77. LEFT JOIN member_users mu1 ON mdt1.object_type = 'App\\Models\\MemberUser' AND mdt1.object_id = mu1.id
  78. /* 二级邀请人关联 */
  79. LEFT JOIN market_dist_teams mdt2 ON cu.id = mdt2.user_id AND mdt2.level = 2
  80. LEFT JOIN coach_info_records ci2 ON mdt2.object_type = 'App\\Models\\CoachUser' AND mdt2.object_id = ci2.coach_id
  81. LEFT JOIN member_users mu2 ON mdt2.object_type = 'App\\Models\\MemberUser' AND mdt2.object_id = mu2.id
  82. WHERE cu.deleted_at IS NULL