12345678910111213141516171819202122232425262728293031 |
- --!syntax_pg
- --TPC-DS Q89
- -- start query 1 in stream 0 using template ../query_templates/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 plato.item, plato.store_sales, plato.date_dim, plato.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 (2000) and
- ((i_category in ('Home','Books','Electronics') and
- i_class in ('wallpaper','parenting','musical')
- )
- or (i_category in ('Shoes','Jewelry','Men') and
- i_class in ('womens','birdal','pants')
- ))
- group by i_category, i_class, i_brand,
- s_store_name, s_company_name, d_moy) tmp1
- where case when (avg_monthly_sales <> 0::numeric) then (abs(sum_sales - avg_monthly_sales) / avg_monthly_sales) else null::numeric end > 0.1::numeric
- order by sum_sales - avg_monthly_sales, s_store_name
- limit 100;
- -- end query 1 in stream 0 using template ../query_templates/query89.tpl
|