title | seoTitle | seoDescription | datePublished | cuid | slug | cover | tags |
---|---|---|---|---|---|---|---|
Executive Dashboard for Cycling Superstores |
Cycling Store Executive Dashboard |
Transform your cycling superstore data into actionable insights with an executive dashboard for informed decision-making |
Fri May 03 2024 09:27:17 GMT+0000 (Coordinated Universal Time) |
clvqh1eid000008ih0p75e9pe |
executive-dashboard-for-cycling-superstores |
postgresql, data-analysis, business, sql, excel, tableau, business-analytics, 2articles1week, cycling, haqqnetwork |
TL;DR
Welcome back, cycling enthusiasts and business aficionados alike. In our previous blog, we witnesssed the transformative power of Business Analysis & Process Management (BA&PM) in optimizing Cycling Superstores' operations. We learnt how BA&PM equips us with the tools and strategies to navigate the challenging terrain of business processes and achieve peak performance iteratively.
And the journey doesn't stop there. Just like a cyclist meticulously analyzes their performance metrics to achieve peak fitness, Cycling Superstores needs to leverage the power of data to gain a deeper understanding of our customers, operations & market landscape.
This is where Business Data Analytics (BDA) steps in. In this blog, we'll unveil the practical of Executive Dashboard with Cycling Superstores. We'll explore how Cycling Superstores can harness the power of data visualization to make informed data-driven decisions, optimize strategies thus accelerate our journey towards long-term success. We’ll be using SQL, Excel & Tableau Public for this project.
“The secret of change is to focus all your energy not on fighting the old but on building the new.” — Socrates
We're creating an executive dashboard for sales at Cycling Superstores, a bicycle retail outlets company. After all, as an avid cyclist what’s not to like when generating income from personal hobbies.
First, by pulling out the relevant data from the company's database using SQL and then defining the business goals and laying out a plan to find a solution towards the aims. Second, collecting and gathering data from various sources based on set priorities. Third, cleaning the data to remove unwanted redundant and missing values that may impede analysis. Fourth, exploring and analyzing the data using business intelligence tools, data visualization, data mining techniques and predictive modeling. Finally, interpreting the results to gain insights.
data:image/s3,"s3://crabby-images/51c9a/51c9aa79a4a6f1ff3bb08fd22788f5e08f47ba5f" alt="Data analysis process: Ask, Prepare, Process, Analyze, Share, Act."
Project Title: Building an Interactive Sales Dashboard for Improved Decision-Making at Cycling Superstores
Problem Statement: Cycling Superstores lacked a centralized and user-friendly platform to analyze sales data. This made it difficult for executives to gain insights into sales performance across various metrics like product category, brand, store location & customer demographics.
Data Sources:
- Relational Database: The project utilized data from Cycling Superstores' internal relational database containing sales transactions, customer information, product details & store locations.
The project involved the following steps:
-
Data Acquisition: SQL queries were written to extract relevant data from the relational database, including order details, customer information, product categories, brands, store locations & sales rep IDs.
-
Data Cleaning: The extracted data was reviewed and cleaned in Excel to address any missing values, inconsistencies, or redundancies.
-
Data Analysis: Pivot tables and charts were used in Excel to analyze sales trends by year, month, state, store, brand, product category, customer & sales rep.
-
Data Visualization:
-
Excel: Charts like line charts, pie charts & bar charts were created to present key sales insights in Excel.
-
Tableau: Interactive visualizations like line charts, map charts, pie charts, tree maps & bar charts were developed in Tableau Public for a more dynamic and informative dashboard.
-
-
Dashboard Creation:
-
Excel: A basic sales dashboard was built in Excel, combining various charts with slicers to allow for interactive filtering by year, state & store name.
-
Tableau: An interactive dashboard was created in Tableau, enabling executives to explore sales data by year, state, store, brand, product category, customer & sales rep. Action filters were implemented to ensure all charts update dynamically based on user selections.
-
The project resulted in several key insights:
-
Seasonal trends were identified in sales data, highlighting peak sales periods.
-
Revenue breakdown by state, store, brand & product category revealed valuable information for targeted marketing campaigns and inventory management.
-
Top-performing customers and sales reps were identified, allowing for recognition and reward programs to boost customer loyalty and sales motivation.
Overall, the interactive sales dashboards empowered executives at Cycling Superstores to make data-driven decisions regarding product offerings, marketing strategies, inventory allocation & sales team performance.
-
Data Wrangling (Data Cleaning & Transformation)
-
SQL Querying via PostgreSQL
-
Data Visualization (Excel Charts & Tableau Dashboards)
-
Business Intelligence Tools (Tableau)
-
VS Code as Code Editor with SQLTools extension
-
The dashboard link for Tableau Public can be accessed here.
-
You can find the GitHub repo for this project here.
First, we need to understand what information management wants to see in the Problem Statement. In this case, we'll create a sales dashboard that provides insights into:
-
Total revenue by year and month
-
Revenue breakdown by state, store, brand, product category & sales rep
-
Top performing customers
Since this problem relates to internal transactions, we'll retrieve the available data from the company's relational database using SQL.
%[https://youtu.be/cc-cSSsGqbA?si=AnKy5bhImRS0H7cU]
Once PostgreSQL installed, we set the following to load the data into our PostgreSQL server database:
-
Download and unzip our raw data →
Cycling-Superstores-Database.zip
-
Open PostgreSQL server via pgAdmin 4, create a new database and name it
CyclingSuperstoresDB
-
Right-click the new
CyclingSuperstoresDB
database in the PostgreSQL server and selectQuery Tool
to open a new query editor tab -
Browse and open the “create objects.sql” from the unzipped file in Step 1 i.e. via Notepad++
-
Copy all from “create objects.sql” and paste it in the query editor
-
Click the ‘Execute/Refresh’ button or press
F5
to run the script. In the message tab, you should be prompted:CREATE TABLE Query returned successfully in 120 msec.
-
Browse and open the “load data.sql” from the unzipped file in Step 1 i.e. via Notepad++
-
Copy all from “load data.sql” and paste it in the query editor and confirm success query. Disclaimer: the next VS Code specific steps onwards are only applicable if you’re using VS Code as the database UI as intended in this project. Otherwise, feel free to proceed with the SQL queries directly within pgAdmin4 Query Tool for postgres or any SQL server to your preference.
-
Create PostgreSQL Server connection via SQLTools extension in VS Code and populate:
-
Connection name:
PG Server Local
-
Server Address:
localhost
-
Database:
CyclingSuperstoresDB
which is already created in the local PostgreSQL server -
And set username and password for it accordingly. Username is the owner of created database which is
postgres
by default. -
Test connection and once successful, save it and connect now.
-
Remember to add
.vscode/
in the.gitignore
to avoid git tracking for confidential information.
-
-
Select the newly connected
CyclingSuperstoresDB
database in the VS Code and we can now building the SQL Query in thePG Server Local.session.sql
.
From our raw data, we'll write an SQL script to generate a dataset containing the following fields:
-
Order ID
-
Customer name (first & last)
-
Customer city & state
-
Order date
-
Sales volume
-
Revenue
-
Product name, category, and brand
-
Store name
-
Sales rep
These fields are spread across several tables in the database. We'll use JOINs to combine the relevant tables based on shared fields like customer ID and product category ID.
Let’s first start with Order ID, Customer name (first & last in one column using CONCAT), Customer city & state and Order date:
SELECT
order_id,
CONCAT(first_name,' ', last_name),
city,
state,
order_date
FROM sales.orders ord
JOIN sales.customers cus
-- we'll combine ord & cus table on their customer_id field
ON ord.customer_id = cus.customer_id
Once that is done, we need to specify which information selected belongs to which table e.g. order_id
belongs to sales order table ord
whilst first_name
and last_name
belongs to cus
table:
SELECT
ord.order_id,
CONCAT(cus.first_name,' ', cus.last_name) AS customers,
cus.city,
cus.state,
ord.order_date
FROM sales.orders ord
JOIN sales.customers cus
-- we'll combine ord & cus table on their customer_id field
ON ord.customer_id = cus.customer_id
We can now query sales volume and revenue, in this case SUM(quantity)
& SUM(quantity*list_price)
respectively:
SELECT
ord.order_id,
CONCAT(cus.first_name,' ', cus.last_name) AS customers,
cus.city,
cus.state,
ord.order_date,
SUM(quantity) AS 'total_units',
SUM(quantity * list_price) AS 'revenue',
FROM sales.orders ord
JOIN sales.customers cus
-- we'll combine ord & cus table on their customer_id field
ON ord.customer_id = cus.customer_id
It would be easier if we also join the sales order items to the sales order table using the order ID field now. We also need to specify that the quantity
and list_price
field belongs to the sales order items, ite
.
JOIN sales.order_items ite
ON ord.order_id = ite.order_id
Added a GROUP BY
clause at the end of the query. This is necessary because we’re using aggregate functions (SUM
) on the quantity
and quantity * list_price
columns. We need to tell SQL how to group the other non-aggregated columns (order_id
, full_name
, city
, state
, order_date
). In this case, we’re grouping by each unique order, along with the customer’s name and location, and the order date.
GROUP BY ord.order_id, customers, cus.city, cus.state, ord.order_date
It would be easier if we know the product name as well which can be added in SELECT
as product_name
and then join the production table. This enables us to join the production products table to the sales order items table using the product ID field.
SELECT
pro.product_name
JOIN production.products pro
ON ite.product_id = pro.product_id
GROUP BY ord.order_id, customers, cus.city, cus.state, ord.order_date, pro.product_name
Introducing category
filter would be another useful metric. It’s found in the production table. Which can be joined from products production table using the category id field.
SELECT
cat.category_name
JOIN production.categories cat
ON pro.category_id = cat.category_id
For targeted local marketing, it makes sense to add store_name
to ascertain which stores sell what products the most. It’s found in the store’s sales
table. And this table can be joined with the sales order table using the store ID field as well as GROUP BY
→sto.store_name
:
SELECT
sto.store_name
JOIN sales.stores sto
ON ord.store_id = sto.store_id
Finally, we’d love to know the sales rep who made the sales. Employee bonus goes a long way. We need to concate first_name
and last_name
from sales staff table and join this table with the sales orders table using the staff ID
field as well as GROUP BY
it:
SELECT
CONCAT(sta.first_name, ' ', sta.last_name) AS sales_rep
JOIN sales.staffs sta
ON ord.staff_id = sta.staff_id
That will do for our query and here’s the sneak peek of the structured data:
data:image/s3,"s3://crabby-images/df783/df7832182a96892f73e5ffe1e38e5094c38fc879" alt="Sneak peak at structured data with the SQL Query above."
For ease of syncing dataset from Postgres to other platforms such as MS Excel, we can create a new table in Postgres Cycling Superstore Public database:
CREATE TABLE public.cc_dashboard AS
Our dataset is comprehensively structured and includes several fields: Order IDs, Customer Names (combining first and last names), Customer Location (city and state), Order Dates, Total Units Sold per order, Revenue Generated per order, Product Names, Bike Brands, Sales Store Location & Sales Representative associated with each transaction.
We can move on the Step 3 of the data analysis process, which is crucial for ensuring the integrity of the sale records, involves cleansing the data to eliminate any unwanted, redundant, or erroneous values that could hinder the analysis.
After importing the data from the Postgres database into Excel, we'll check for missing values, redundancies, or inconsistencies that might hinder analysis. In our case, the data appears clean and ready for further exploration.
data:image/s3,"s3://crabby-images/41469/41469be33300c8773ff8914223af3b1d7f6eeb7c" alt=""
Now, it's time to create some visuals. We'll use Excel's pivot tables and charts to present the data in a clear and concise way. Here are some examples of the charts we'll create:
-
Total Revenue: Pivot tables and charts showing total revenue by year and month. Since both table based from the same dataset, we need to decouple them by using command
[Alt + D, P](<
https://sheetleveller.com/open-pivot-table-wizard/
>)
for Windows when creating the second table.-
By Year:
data:image/s3,"s3://crabby-images/489ec/489ec06f9cc9c7d8cf320d914fe986e5c90ded93" alt=""
-
By Month:
data:image/s3,"s3://crabby-images/824c5/824c53d77f901db85c789f0e483334e6c6ee52a0" alt=""
-
By Chart:
data:image/s3,"s3://crabby-images/46b4f/46b4f76d54d18d0f42ea2a32d1e93c799ae26553" alt=""
-
Revenue Breakdown: Charts illustrating revenue by state, store, product category, and top 10 customers.
-
Revenue by State:
data:image/s3,"s3://crabby-images/28e1a/28e1aa9e7a08f3c294227276fd3267747626cd59" alt=""
-
Revenue by Store:
data:image/s3,"s3://crabby-images/6b57c/6b57c9a8bb23ce7b2032191a8e85e6bedc853498" alt=""
-
Revenue by Product Category:
data:image/s3,"s3://crabby-images/7a867/7a8670bd85111a88564e8e1fbc4c1f09efd61ebb" alt=""
-
Top 10 Customers:
data:image/s3,"s3://crabby-images/66b97/66b971c1969bf77b256515129480e02a0a36cd64" alt=""
-
Revenue per Sales Rep:
data:image/s3,"s3://crabby-images/37975/379758fe7f245d1a67cb835ac6594b3bea4e6ee5" alt=""
-
-
-
We'll combine the charts into a single dashboard to provide a holistic view of sales performance. Additionally, we can add slicers to filter the data by year, state, and store name, allowing for interactive exploratory data analysis (EDA).
data:image/s3,"s3://crabby-images/43cdf/43cdf381084e0d3db074665fe1570fa0ef342606" alt=""
-
Use the slicers to select the desired year, state, or store name.
-
Observe how the charts dynamically update to reflect the filtered data.
-
Explore different combinations of filters to uncover trends and patterns in sales performance.
By leveraging this interactive dashboard, stakeholders can make informed decisions based on real-time data analysis.
data:image/s3,"s3://crabby-images/3dc41/3dc41c2d6a6357f802159055007fbe835e60a47c" alt=""
While Excel offers basic dashboarding capabilities, it might not be ideal for very large datasets. We acknowledge this limitation and introduce Tableau as an alternative for complex BI visualizations especially those who works with large dataset, requires advance viz and guided analysis feature.
We'll import the Excel data set into Tableau Desktop Public Edition and create interactive visualizations:
-
Revenue per Year & Month: Bar and Line chart showing yearly & monthly revenue with a year filter.
-
Revenue by State and Store: Map and pie charts for revenue breakdown by state and store.
-
Revenue by Product Category: Treemap for revenue breakdown by product category.
-
Top Customers and Revenue per Sales Rep: Bar charts with a parameter filter to control the number of displayed key figures.
We'll create action filters in Tableau to allow management to explore the data dynamically. By clicking on a specific year, state, or sales rep in one chart, all other charts will update to reflect the chosen filter.
Final Touches and Sharing
We'll finalize the design of both the Excel and Tableau dashboards, ensuring they are visually appealing and user-friendly. Finally, we'll upload the Tableau dashboard to Tableau Public for easy access and sharing.
data:image/s3,"s3://crabby-images/281c6/281c64f6a4a7a5f9708e28c1135fce685ff0b789" alt=""
For interactive Cycling Superstores Tableau Dashboard, feel free to visit Tableau Public.
Based on the findings from the dashboard and discussion with stakeholders, we can suggests some potential areas for further investigation:
-
Sales Rep Performance: The revenue per sales rep chart allows management to identify top performers and potentially low performers. They could use this information to implement sales incentives, provide additional training, or optimize team structures.
-
Sales Trends: By viewing revenue per year and month charts, management can identify seasonal trends or track the effectiveness of marketing campaigns. They could use this information to adjust sales strategies or resource allocation throughout the year.
-
Geographic Performance: The map chart reveals sales distribution across different states. Management could use this information to focus marketing efforts on underperforming regions or tailor product offerings based on regional preferences.
-
Customer Analysis: Although not yet carried out, insights via customer survey from top customer analysis can be conducted to understand their buying patterns and preferences. This could inform targeted marketing campaigns or loyalty programs.
Other than that, we can point out additional analysis to consider:
-
Drill down analysis: The current visualizations provide a high-level overview. Management might want to explore the data further by drilling down into specific regions, product categories, or sales rep performance for a particular month.
-
Goal setting and monitoring: The dashboard can be used to set performance goals and monitor progress over time. For example, management could set annual sales targets by region or track the effectiveness of a new marketing campaign by comparing sales figures before and after the launch.
-
Guided analysis: Once we gain more insights from the above analyses, we can formulate clearer questions and move on guided analysis to answer these specific questions as data-driven business decisions.
By using the dashboard interactively and asking further questions, management can gain deeper insights and take concrete actions to improve the company's performance.
Based on our current dashboard, we could oversee some additional columns of data that could be useful:
Customer Data:
-
Customer Lifetime Value (CLTV): This metric indicates the total revenue a customer is expected to generate over their relationship with the company. It can help identify valuable customers and guide targeted marketing campaigns.
-
Customer Acquisition Cost (CAC): This metric represents the cost of acquiring a new customer. By comparing CLTV to CAC, management can assess the profitability of customer acquisition strategies.
-
Purchase Frequency: This metric tracks how often a customer makes a purchase. It can help identify loyal customers and inform strategies to encourage repeat business.
-
Average Order Value (AOV): This metric represents the average amount a customer spends per order. This can be used to identify opportunities to upsell or cross-sell products.
Product Data:
-
Profit Margin: This metric shows the profit earned on each product after accounting for its production and selling costs. It can help guide product pricing strategies and identify areas for cost optimization.
-
Product Category: Granular product category data beyond the current brand categorization can allow for more focused analysis of sales trends and customer preferences within specific product types (e.g., road bikes vs. mountain bikes).
-
Product Cost: Knowing the cost of each product would be essential for calculating profit margins.
Sales Data:
-
Discount Used: Tracking the type and amount of discounts offered can help analyze their effectiveness in driving sales and identify potential areas for optimizing pricing strategies.
-
Marketing Channel: Identifying the marketing channel through which a sale was generated (e.g., online advertising, social media, in-store promotion, HAQQ Web3 challenges) allows for a more targeted evaluation of marketing campaign performance.
-
Customer Acquisition Channel: Understanding how customers were initially acquired (e.g., referral program, online search, ) can inform strategies for attracting new customers.
Time-Based Data:
-
Day of Week: Sales data segmented by day of the week can reveal patterns in customer buying behavior and optimize staffing or marketing efforts accordingly.
-
Hour of Day: Similar to day of the week, understanding sales patterns by hour of the day can inform decisions about online store operating hours or targeted marketing campaigns during peak buying times.
Including some of this data could enable a richer analysis of sales performance, customer behavior, and marketing effectiveness. The specific additional data points that would be most beneficial will depend on the company's specific goals and areas of interest.
This comprehensive portfolio showcases business data analytics using SQL, create insightful visualizations with Excel and Tableau, and build interactive dashboards to communicate complex information effectively.
Overall, the dashboard empowers management to make data-driven decisions about sales strategies, resource allocation, marketing campaigns & customer relationship management.
data:image/s3,"s3://crabby-images/4873a/4873a5a1704f4d228f0f8d8e9a8a72bd273f313d" alt=""
Warning: May cause increased data enthusiasm. Read the next post in Data Series at your own risk.
Want to see more content like this? Consider supporting us by hitting the Sponsor button if you found value in our articles. 💚