-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathproject sql.sql
More file actions
71 lines (65 loc) · 1.98 KB
/
project sql.sql
File metadata and controls
71 lines (65 loc) · 1.98 KB
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
SELECT * FROM df_orders
-- find top 10 highest revenue generating products
select product_id, sum(sale_price) as sales
from df_orders
group by product_id
order by sales desc
limit 10;
-- find top 5 highest selling products in each region
with cte as (
select region, product_id, SUM(sale_price) AS sales
from df_orders
group by region, product_id
)
select *
from (
select *, row_number() over (partition by region order by sales desc) as rn
from cte
) as A
where rn <= 5;
-- find month over month growth comparision for 2022 and 2023 sales example: jan 2022 vs jan 2023
with cte as (
select year(order_date) as order_year, month(order_date) as order_month,
sum(sale_price) as sales
from df_orders
group by year(order_date), month(order_date)
-- order by year(order_date), month(order_date)
)
select order_month
, sum(case when order_year = 2022 then sales else 0 end) as sales_2022
, sum(case when order_year = 2023 then sales else 0 end) as sales_2023
from cte
group by order_month
order by order_month
-- for each category which month has highest sales
with cte as(
select category, date_format(order_date, '%y%m') as order_year_month,
sum(sale_price) as sales
from df_orders
group by category, order_year_month
-- order by category, order_year_month
)
select * from(
select *, row_number() over (partition by category order by sales desc) as rn
from cte
) a
where rn = 1
-- which sub category had highest growth by profit in 2023 compare to 2022
with cte as (
select sub_category, year(order_date) as order_year,
sum(sale_price) as sales
from df_orders
group by sub_category, year(order_date)
-- order by year(order_date), month(order_date)
), cte2 as (
select sub_category
, sum(case when order_year = 2022 then sales else 0 end) as sales_2022
, sum(case when order_year = 2023 then sales else 0 end) as sales_2023
from cte
group by sub_category
)
select *
, (sales_2023 - sales_2022) * 100 / sales_2022
from cte2
order by (sales_2023 - sales_2022) * 100 / sales_2022 desc
limit 1