-
Notifications
You must be signed in to change notification settings - Fork 32
/
query89.sql
40 lines (40 loc) · 1.44 KB
/
query89.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 89 in stream 0 using template query89.tpl
SELECT *
FROM (SELECT i_category,
i_class,
i_brand,
s_store_name,
s_company_name,
d_moy,
Sum(ss_sales_price) sum_sales,
Avg(Sum(ss_sales_price))
OVER (
partition BY i_category, i_brand, s_store_name, s_company_name
)
avg_monthly_sales
FROM item,
store_sales,
date_dim,
store
WHERE ss_item_sk = i_item_sk
AND ss_sold_date_sk = d_date_sk
AND ss_store_sk = s_store_sk
AND d_year IN ( 2002 )
AND ( ( i_category IN ( 'Home', 'Men', 'Sports' )
AND i_class IN ( 'paint', 'accessories', 'fitness' ) )
OR ( i_category IN ( 'Shoes', 'Jewelry', 'Women' )
AND i_class IN ( 'mens', 'pendants', 'swimwear' ) ) )
GROUP BY i_category,
i_class,
i_brand,
s_store_name,
s_company_name,
d_moy) tmp1
WHERE CASE
WHEN ( avg_monthly_sales <> 0 ) THEN (
Abs(sum_sales - avg_monthly_sales) / avg_monthly_sales )
ELSE NULL
END > 0.1
ORDER BY sum_sales - avg_monthly_sales,
s_store_name
LIMIT 100;