-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathquery70.sql
40 lines (40 loc) · 1.77 KB
/
query70.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
-- start query 70 in stream 0 using template query70.tpl
SELECT Sum(ss_net_profit) AS total_sum,
s_state,
s_county,
Grouping(s_state) + Grouping(s_county) AS lochierarchy,
Rank()
OVER (
partition BY Grouping(s_state)+Grouping(s_county), CASE WHEN
Grouping(
s_county) = 0 THEN s_state END
ORDER BY Sum(ss_net_profit) DESC) AS rank_within_parent
FROM store_sales,
date_dim d1,
store
WHERE d1.d_month_seq BETWEEN 1200 AND 1200 + 11
AND d1.d_date_sk = ss_sold_date_sk
AND s_store_sk = ss_store_sk
AND s_state IN (SELECT s_state
FROM (SELECT s_state AS
s_state,
Rank()
OVER (
partition BY s_state
ORDER BY Sum(ss_net_profit) DESC) AS
ranking
FROM store_sales,
store,
date_dim
WHERE d_month_seq BETWEEN 1200 AND 1200 + 11
AND d_date_sk = ss_sold_date_sk
AND s_store_sk = ss_store_sk
GROUP BY s_state) tmp1
WHERE ranking <= 5)
GROUP BY rollup( s_state, s_county )
ORDER BY lochierarchy DESC,
CASE
WHEN lochierarchy = 0 THEN s_state
END,
rank_within_parent
LIMIT 100;