-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsql_query_Retail Sales Analysis.sql
More file actions
164 lines (127 loc) · 3.63 KB
/
sql_query_Retail Sales Analysis.sql
File metadata and controls
164 lines (127 loc) · 3.63 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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
drop table if exists retail_sales;
CREATE table retail_sales (
transactions_id int,
sale_date date,
sale_time time,
customer_id INT,
gender varchar(10),
age int,
category varchar(20),
quantity int,
price_per_unit float,
cogs float,
total_sale float
);
select * from retail_sales;
select
*
from retail_sales where age is null;
select * from retail_sales
where
transactions_id is null
or
sale_date is null
or
sale_time is null
or
gender is null
or
category is null
or
quantity is null
or
cogs is null
or
total_sale is null;
delete from retail_sales
where
transactions_id is null
or
sale_date is null
or
sale_time is null
or
gender is null
or
category is null
or
quantity is null
or
cogs is null
or
total_sale is null;
-- Data Exploration --
-- How many sales? --
select sum(total_sale) from retail_sales;
-- How many customers we have --
select count(distinct customer_id) from retail_sales;
select distinct category from retail_sales;
-- Data Analysis and Business Key Problems and Answers --
-- My Analysis & Findings
-- Q.1 Write a SQL query to retrieve all columns for sales made on '2022-11-05
select * from retail_sales
where sale_date='2022-11-05';
-- Q.2 Write a SQL query to retrieve all transactions where the category is 'Clothing' and the quantity sold is more than 4 in the month of Nov-2022
select * from retail_sales
where
category='Clothing'
and
quantity>3
and
to_char(sale_date,'yyyy-mm')='2022-11';
-- Q.3 Write a SQL query to calculate the total sales (total_sale) for each category.
select
category,
sum(total_sale) as Total_Amount
from retail_sales
group by category;
-- Q.4 Write a SQL query to find the average age of customers who purchased items from the 'Beauty' category.
select round(avg(age),2) as avg_age from retail_sales where category='Beauty';
-- Q.5 Write a SQL query to find all transactions where the total_sale is greater than 1000.
select
*
from retail_sales
where
total_sale>1000;
-- Q.6 Write a SQL query to find the total number of transactions (transaction_id) made by each gender in each category.
select
gender, category,
count(transactions_id) as number_of_orders
from retail_sales
group by 1,2;
-- Q.7 Write a SQL query to calculate the average sale for each month. Find out best selling month in each year
select sale_year,sale_month,avg_sale from(
select
extract(year from sale_date) as sale_year,
extract(month from sale_date) as sale_month,
avg(total_sale) as avg_sale,
rank() over(partition by extract(year from sale_date) order by avg(total_sale) desc) as rank
from retail_sales
group by 1,2)
where rank=1;
-- Q.8 Write a SQL query to find the top 5 customers based on the highest total sales
select
customer_id,
sum(total_sale)
from retail_sales
group by customer_id
order by sum(total_sale) desc limit 5;
-- Q.9 Write a SQL query to find the number of unique customers who purchased items from each category.
SELECT
category,
count(distinct customer_id)
from retail_sales
group by 1 order by 1,2;
-- Q.10 Write a SQL query to create each shift and number of orders (Example Morning <=12, Afternoon Between 12 & 17, Evening >17)
with hourly_sale
as (
select *,
case
when extract(hour from sale_time)<12 then 'Morning'
when extract(hour from sale_time)<17 then 'Afternoon'
else 'Evening'
END shift
from retail_sales
)
select shift,count(transactions_id) from hourly_sale
group by shift;