Advertisement
ahmedrahil786

All reservations by members - for Study of MFTs - Rahil

Jan 24th, 2020
153
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.84 KB | None | 0 0
  1. set @startdate1 = '2017-01-01';
  2. set @startdate2 = '2020-12-31';
  3. use socar_malaysia;
  4.  
  5. select A.return_date as return_date, A.rid2 as rid, A.mid as mid, A.region as region, A.city as city,A.dur as dur,A.ad_sdur as ad_sdur, A.age as age, IFNULL(E.charges,0) as gross_rev,
  6. IFNULL(F.coupon_Spent,0) as Coupon_Spent, round((IFNULL(E.charges,0) - IFNULL(F.coupon_Spent,0)),2) as net_rev, if(rid2=firstRes,1,0) as mft
  7. from
  8. (select
  9. distinct r.id as rid2, r.member_id as mid, z.region, z.city,
  10. round(sum(timestampdiff(minute, r.start_at, r.end_at)/60),2) as dur,
  11. ifnull((select min(id) from reservations where state='completed' and r.member_id=member_id group by member_id),0) as firstRes,
  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. (YEAR(r.start_at) - YEAR(m.birthday)) as age
  15. from reservations r left join members m on r.member_id = m.id
  16. left join zones z on z.id = r.start_zone_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 (YEAR(r.start_at) - YEAR(m.birthday)) < 100
  23. group by rid2) A
  24. left join
  25. (select c.reservation_id as rid, sum(c.amount) as charges from charges c
  26. where c.state='normal' and c.kind in ('rent','oneway','d2d','mileage','insurance')
  27. group by rid) E on A.rid2 = E.rid
  28. left join
  29. (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
  30. where p.state = 'normal' and p.paid_type = 'coupon'
  31. group by p.reservation_id) F on A.rid2 = F.rid
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement