07代理列表.sql 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. -- Active: xiaoding_test@@192.168.110.85@3306@xiaoding_test
  2. /*
  3. 您是一位专业的dba,同时会业务分析。请参考以上数据库的设计文档,给我写一个sql,关联查询出:代理昵称、申请时间、性别、头像、联系电话、代理地区、总收益金额、体现金额、余额
  4. 请按照的我的要求生成查询sql语句:
  5. 1. 请从如下 agent_infos member_users wallet wallet_withdraw_records等一些表查找
  6. 2. agent_infos通过user_id关联的member_users表
  7. 3. wallet 和 member_users通过判断owner_type和owner_id关联
  8. 4. wallet_withdraw_records和wallet通过wallet_id关联
  9. */
  10. DROP TABLE IF EXISTS report_agent_list;
  11. CREATE TABLE report_agent_list AS
  12. /* 代理列表视图 */
  13. DROP VIEW IF EXISTS manage_agent_list;
  14. CREATE OR REPLACE VIEW manage_agent_list AS
  15. WITH
  16. agent_withdraw AS (
  17. SELECT w.owner_id, COALESCE(SUM(wr.amount), 0) AS total_withdraw_amount /* 总提现金额 */
  18. FROM
  19. wallet w
  20. LEFT JOIN wallet_withdraw_records wr ON w.id = wr.wallet_id
  21. AND wr.audit_state = 'approved'
  22. AND wr.state = 'success'
  23. WHERE
  24. w.owner_type = '3'
  25. GROUP BY
  26. w.owner_id
  27. )
  28. SELECT
  29. mu.nickname as agent_nickname /* 代理昵称 */,
  30. ai.created_at as apply_time /* 申请时间 */,
  31. mu.gender as gender /* 性别 */,
  32. mu.avatar as avatar /* 头像 */,
  33. mu.mobile as mobile /* 联系电话 */,
  34. ai.area_code as area /* 代理地区 */,
  35. COALESCE(w.total_income, 0) as total_income /* 总收益金额 */,
  36. COALESCE(aw.total_withdraw_amount, 0) as withdraw_amount /* 提现金额 */,
  37. COALESCE(w.available_balance, 0) as balance /* 余额 */
  38. FROM
  39. agent_infos ai
  40. INNER JOIN member_users mu ON ai.user_id = mu.id
  41. LEFT JOIN wallet w ON w.owner_id = ai.id
  42. AND w.owner_type = '3'
  43. LEFT JOIN agent_withdraw aw ON aw.owner_id = mu.id
  44. WHERE
  45. ai.deleted_at IS NULL
  46. AND mu.deleted_at IS NULL
  47. AND w.deleted_at IS NULL;
  48. select *
  49. from
  50. agent_infos as ag
  51. inner join member_users as mu on ag.user_id = mu.id;