-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgrafana_queries.sql
84 lines (82 loc) · 1.69 KB
/
grafana_queries.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
-- percent change cost by service
with cost_per_project as (
select
sum(cost) as cost,
service_id,
invoice_date
from
cost
group by
2,3
having
sum(cost) > 10 -- only consider services where the cost is > 10
),
lag_cost_per_project as (
select
cost,
service_id,
invoice_date,
lag(cost) over (partition by service_id order by invoice_date) as previous_month_running_costs
from
cost_per_project
),
service_percent_change as (
select
*,
coalesce(round((cost - previous_month_running_costs) / coalesce(nullif(previous_month_running_costs,0), 1) * 100),0) as percent_change
from
lag_cost_per_project
)
select
service_name,
percent_change
from
service_percent_change c, service s
where
s.service_id = c.service_id and
c.percent_change > 0 and
c.invoice_date = '2024-01-31'
order by
c.percent_change desc
limit 10;
with cost_per_service as (
select
sum(cost) as cost,
project_id,
invoice_date
from
cost
group by
2,3
having
sum(cost) > 10 -- only consider services where the cost is > 10
),
lag_cost_per_service as (
select
cost,
project_id,
invoice_date,
lag(cost) over (partition by project_id order by invoice_date) as previous_month_running_costs
from
cost_per_service
),
project_percent_change as (
select
*,
coalesce(round((cost - previous_month_running_costs) / coalesce(nullif(previous_month_running_costs,0), 1) * 100),0) as percent_change
from
lag_cost_per_service
)
select
project_name,
percent_change
from
project_percent_change c,
project p
where
c.project_id = p.project_id and
c.percent_change > 0 and
c.invoice_date = '2024-01-31'
order by
c.percent_change desc
limit 10;