Advertisement
ahmedrahil786

Grabpay MFTs >3 hours, >50 RM Spent - Rahil Query for Viny

Dec 5th, 2019
187
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.64 KB | None | 0 0
  1. ############ Query to Find the MFTs whose duration is greater than 3 Hours
  2.  
  3. set @startdate1 = '2019-11-01';
  4. set @startdate2 = '2020-12-01';
  5. use socar_malaysia;
  6. Select distinct I.mid as mid, I.name as name, I.email as email, I.Phone as phone, I.return_date as date, Week(I.return_date) as week , I.dur as duration from
  7. (select A.return_date as return_date, A.rid2 as rid,A.mid as mid, A.provider as provider , A.dur as dur, A.ad_sdur as ad_sdur,A.name as name, A.email as email, A.phone as phone, if(rid2=firstRes,1,0) as mft from
  8. (select
  9. distinct r.id as rid2, r.member_id as mid,p.paygate as provider, m.display_name as name, m.email as email, ma.phone as phone,
  10. ifnull((select min(id) from reservations where state='completed' and r.member_id=member_id group by member_id),0) as firstRes,
  11. round(sum(timestampdiff(minute, r.start_at, r.end_at)/60),2) as dur,
  12. round(sum(floor(timestampdiff(minute, r.start_at, r.end_at)/60/24)*12+if(mod(timestampdiff(hour, r.start_at, r.end_at),24)>=12,12,mod(timestampdiff(minute, r.start_at, r.end_at)/60,24))),2) as ad_sdur,
  13. Date(r.return_at + interval '8' hour) as return_Date
  14. from reservations r left join members m on r.member_id = m.id
  15. left join payments p on p.reservation_id = r.id
  16. left join member_appendixes ma on ma.member_id = m.id
  17. where r.state in ('completed')
  18. and r.return_at + interval 8 hour >= @startdate1
  19. and r.return_at + interval 8 hour <= @startdate2
  20. and m.imaginary in ('sofam', 'normal')
  21. and r.member_id not in ('125', '127')
  22. and p.paygate is not null
  23. group by rid2) A) I
  24. where I.mft = 1
  25. and I.provider like 'grabpay'
  26. and I.dur >= 3
  27. and week(I.return_date) >= '46'
  28. order by I.return_date asc ;
  29.  
  30. ############ Query to Find the MFTs who spent more than 50 with Grabpay
  31.  
  32. set @startdate1 = '2019-11-01';
  33. set @startdate2 = '2020-12-01';
  34. use socar_malaysia;
  35. Select distinct I.mid as mid, I.name as name, I.email as email, I.Phone as phone, I.return_date as date, Week(I.return_date) as week , I.dur as duration , I.net_rev from
  36. (select A.return_date as return_date, A.rid2 as rid,A.mid as mid, A.provider as provider , A.dur as dur, A.name as name, A.email as email, A.phone as phone, if(rid2=firstRes,1,0) as mft ,
  37. round((IFNULL(E.charges,0) - IFNULL(F.coupon_Spent,0)),2) as net_rev from
  38. (select
  39. distinct r.id as rid2, r.member_id as mid,p.paygate as provider, m.display_name as name, m.email as email, ma.phone as phone,
  40. ifnull((select min(id) from reservations where state='completed' and r.member_id=member_id group by member_id),0) as firstRes,
  41. round(sum(timestampdiff(minute, r.start_at, r.end_at)/60),2) as dur,
  42. Date(r.return_at + interval '8' hour) as return_Date
  43. from reservations r left join members m on r.member_id = m.id
  44. left join payments p on p.reservation_id = r.id
  45. left join member_appendixes ma on ma.member_id = m.id
  46. where r.state in ('completed')
  47. and r.return_at + interval 8 hour >= @startdate1
  48. and r.return_at + interval 8 hour <= @startdate2
  49. and m.imaginary in ('sofam', 'normal')
  50. and r.member_id not in ('125', '127')
  51. and p.paygate is not null
  52. group by rid2) A
  53. left join
  54. (select c.reservation_id as rid, sum(c.amount) as charges from charges c
  55. where c.state='normal' and c.kind in ('rent','oneway','d2d','mileage','insurance')
  56. group by rid) E on A.rid2 = E.rid
  57. left join
  58. (select p.reservation_id as rid, month(p.created_at + interval '8' hour) as month,Year(p.created_at + interval '8' hour) as year, IFNULL(p.amount,0) as coupon_Spent from payments p
  59. where p.state = 'normal' and p.paid_type = 'coupon'
  60. group by p.reservation_id) F on A.rid2 = F.rid) I
  61. where I.mft = 1
  62. and I.provider like 'grabpay'
  63. and I.net_rev >= '50'
  64. and week(I.return_date) >= '46'
  65. order by I.return_date asc
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement