Medium
Table: stores
+------------+----------+
| Column Name| Type |
+------------+----------+
| store_id | int |
| store_name | varchar |
| location | varchar |
+------------+----------+
store_id is the unique identifier for this table.
Each row contains information about a store and its location.
Table: inventory
+--------------+----------+
| Column Name | Type |
+--------------+----------+
| inventory_id | int |
| store_id | int |
| product_name | varchar |
| quantity | int |
| price | decimal |
+--------------+----------+
inventory_id is the unique identifier for this table.
Each row represents the inventory of a specific product at a specific store.
Write a solution to find stores that have inventory imbalance - stores where the most expensive product has lower stock than the cheapest product.
3
different productsReturn the result table ordered by imbalance ratio in descending order, then by store name in ascending order.
The result format is in the following example.
Example:
Input:
stores table:
+----------+----------------+-------------+
| store_id | store_name | location |
+----------+----------------+-------------+
| 1 | Downtown Tech | New York |
| 2 | Suburb Mall | Chicago |
| 3 | City Center | Los Angeles |
| 4 | Corner Shop | Miami |
| 5 | Plaza Store | Seattle |
+----------+----------------+-------------+
inventory table:
+--------------+----------+--------------+----------+--------+
| inventory_id | store_id | product_name | quantity | price |
+--------------+----------+--------------+----------+--------+
| 1 | 1 | Laptop | 5 | 999.99 |
| 2 | 1 | Mouse | 50 | 19.99 |
| 3 | 1 | Keyboard | 25 | 79.99 |
| 4 | 1 | Monitor | 15 | 299.99 |
| 5 | 2 | Phone | 3 | 699.99 |
| 6 | 2 | Charger | 100 | 25.99 |
| 7 | 2 | Case | 75 | 15.99 |
| 8 | 2 | Headphones | 20 | 149.99 |
| 9 | 3 | Tablet | 2 | 499.99 |
| 10 | 3 | Stylus | 80 | 29.99 |
| 11 | 3 | Cover | 60 | 39.99 |
| 12 | 4 | Watch | 10 | 299.99 |
| 13 | 4 | Band | 25 | 49.99 |
| 14 | 5 | Camera | 8 | 599.99 |
| 15 | 5 | Lens | 12 | 199.99 |
+--------------+----------+--------------+----------+--------+
Output:
+----------+----------------+-------------+------------------+--------------------+------------------+
| store_id | store_name | location | most_exp_product | cheapest_product | imbalance_ratio |
+----------+----------------+-------------+------------------+--------------------+------------------+
| 3 | City Center | Los Angeles | Tablet | Stylus | 40.00 |
| 1 | Downtown Tech | New York | Laptop | Mouse | 10.00 |
| 2 | Suburb Mall | Chicago | Phone | Case | 25.00 |
+----------+----------------+-------------+------------------+--------------------+------------------+
Explanation:
The Results table is ordered by imbalance ratio in descending order, then by store name in ascending order
# Write your MySQL query statement below
WITH store_product_check AS (
SELECT
s.store_id,
s.store_name,
s.location,
COUNT(i.inventory_id) AS store_product_ct
FROM
stores s
JOIN inventory i ON s.store_id = i.store_id
GROUP BY
s.store_id,
s.store_name,
s.location
HAVING
COUNT(i.inventory_id) >= 3
),
store_product_ranked AS (
SELECT
s.store_id,
s.store_name,
s.location,
i.inventory_id,
i.product_name,
i.quantity,
i.price,
ROW_NUMBER() OVER (PARTITION BY s.store_id ORDER BY i.price ASC) AS low_price_rk,
ROW_NUMBER() OVER (PARTITION BY s.store_id ORDER BY i.price DESC) AS high_price_rk
FROM
stores s
JOIN inventory i ON s.store_id = i.store_id
),
high_low_price AS (
SELECT
spc.store_id,
spc.store_name,
spc.location,
lp.product_name AS low_price_product_name,
lp.quantity + 0.0 AS low_price_quantity,
hp.product_name AS high_price_product_name,
hp.quantity + 0.0 AS high_price_quantity
FROM
store_product_check spc
JOIN store_product_ranked lp
ON spc.store_id = lp.store_id AND lp.low_price_rk = 1
JOIN store_product_ranked hp
ON spc.store_id = hp.store_id AND hp.high_price_rk = 1
)
SELECT
hlp.store_id,
hlp.store_name,
hlp.location,
hlp.high_price_product_name AS most_exp_product,
hlp.low_price_product_name AS cheapest_product,
ROUND(hlp.low_price_quantity / hlp.high_price_quantity, 2) AS imbalance_ratio
FROM
high_low_price hlp
WHERE
hlp.high_price_quantity < hlp.low_price_quantity
ORDER BY
imbalance_ratio DESC,
hlp.store_name ASC;