-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcustomer_behaviour.sql
More file actions
85 lines (72 loc) · 2.82 KB
/
customer_behaviour.sql
File metadata and controls
85 lines (72 loc) · 2.82 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
create database customer_behaviour;
select * from customer;
-- Q1. What is the total revenue generated by male vs female customers?
select gender, sum(purchase_amount) as revenue
from customer
group by gender;
-- Q2. Which customers used a discount but still spent more than the average purchase amount?
select customer_id, purchase_amount
from customer
where discount_applied = 'Yes' and purchase_amount >= (select avg(purchase_amount) from customer);
-- Q3. Which are the top 5 products with the highest average review rating?
select
item_purchased,
round(avg(review_rating), 2) as 'Average Product Rating'
from customer
group by item_purchased
order by avg(review_rating) desc
limit 5;
-- Q4. Compare the average purchase amounts between standard and express shipping?
select shipping_type,
round(avg(purchase_amount),2) as 'Average Purchase Amount'
from customer
where shipping_type in ('Standard', 'Express')
group by shipping_type;
-- Q5. Do subscribed customers spend more? Compare average spend and total revenue between subscribers and non-subscribers?
select subscription_status,
count(customer_id) as total_customers,
round(avg(purchase_amount),2) as avg_spend,
round(sum(purchase_amount),2) as total_revenue
from customer
group by subscription_status
order by avg_spend, total_revenue desc;
-- Q6. Which 5 products have the highest percentage of purchase with discounts applied?
select item_purchased,
round(100 * sum(case when discount_applied = 'Yes' then 1 else 0 end)/count(*),2) as discount_rate
from customer
group by item_purchased
order by discount_rate desc
limit 5;
-- Q7. Segment customers into new, returning and loyal based on their total number of previous purchases and show the count of each segment?
with customer_type as(
select customer_id, previous_purchases,
case
when previous_purchases = 1 then 'New'
when previous_purchases between 2 and 10 then 'Returning'
else 'Loyal'
end as customer_segment
from customer
)
select customer_segment, count(*) as 'Number of Customers'
from customer_type
group by customer_segment;
-- Q8. What are the top 3 most purchased products within each category?
with item_counts as(
select category, item_purchased, count(customer_id) as total_orders,
row_number() over(partition by category order by count(customer_id) desc) as item_rank
from customer
group by category, item_purchased
)
select item_rank, category, item_purchased, total_orders
from item_counts
where item_rank <= 3;
-- Q9. Are customers who are repeat buyers(more than 5 previous purchases)also likely to subscribe?
select subscription_status, count(customer_id) as repeat_customers
from customer
where previous_purchases > 5
group by subscription_status;
-- Q10. What is the revenue contribution of each age group?
select age_group, sum(purchase_amount) as total_revenue
from customer
group by age_group
order by total_revenue desc;