computer-scienceangular-roadmapbackend-roadmapblockchain-roadmapdba-roadmapdeveloper-roadmapdevops-roadmapfrontend-roadmapgo-roadmaphactoberfestjava-roadmapjavascript-roadmapnodejs-roadmappython-roadmapqa-roadmapreact-roadmaproadmapstudy-planvue-roadmapweb3-roadmap
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2.5 KiB
2.5 KiB
title | description | order | type | setup |
---|---|---|---|---|
Books Above Average | Practice using simple subqueries to find books above average price | 141 | challenge | ```sql CREATE TABLE book ( id INT PRIMARY KEY, title VARCHAR(100), category VARCHAR(50), price DECIMAL(10,2), stock INT ); INSERT INTO book (id, title, category, price, stock) VALUES (1, 'SQL Basics', 'Programming', 29.99, 10), (2, 'Advanced SQL', 'Programming', 49.99, 5), (3, 'Data Science', 'Data Analysis', 39.99, 8), (4, 'Web Development', 'Programming', 34.99, 12), (5, 'Statistics 101', 'Data Analysis', 24.99, 15), (6, 'Machine Learning', 'Data Analysis', 44.99, 6); ``` |
The bookstore manager wants to identify expensive books that might need a price adjustment. They need to find all books that are priced above the average book price.
Given the following data in table book
:
id | title | category | price | stock |
---|---|---|---|---|
1 | SQL Basics | Programming | 29.99 | 10 |
2 | Advanced SQL | Programming | 49.99 | 5 |
3 | Data Science | Data Analysis | 39.99 | 8 |
4 | Web Development | Programming | 34.99 | 12 |
5 | Statistics 101 | Data Analysis | 24.99 | 15 |
6 | Machine Learning | Data Analysis | 44.99 | 6 |
Write a query that shows:
- Book title
- Category
- Price
- How much the price is above the average (rounded to 2 decimal places)
Only include books that are priced above the average book price.
Expected Output
title | category | price | above_average |
---|---|---|---|
Advanced SQL | Programming | 49.99 | 12.66 |
Machine Learning | Data Analysis | 44.99 | 7.66 |
Data Science | Data Analysis | 39.99 | 2.66 |
Note: The average book price is 37.33
Solution
SELECT
title,
category,
price,
ROUND(price - (
SELECT AVG(price)
FROM book
), 2) as above_average
FROM book
WHERE price > (
SELECT AVG(price)
FROM book
)
ORDER BY price DESC;
This challenge requires you to:
- Calculate the average price using a subquery
- Compare each book's price to this average
- Show how much each book is above the average price
The solution demonstrates the use of subqueries:
- In the SELECT clause to calculate the difference from average
- In the WHERE clause to filter for above-average prices