Analysing Book Store Sample Data with PostgreSQL
Writing complex SQL queries
data:image/s3,"s3://crabby-images/38732/387326412ef8443c75ce4ccb597e543851733fb2" alt=""
Requirements
The Product Owner needs a daily report showing :
- the order date
- the number of orders for that date
- the number of books ordered
- the total price of the orders
- the running total of books for the month
- the number of books from the same day last week (e.g. how this Monday compares to last Monday)
An annual report showing :
- year
- the book title
- the number of books sold
- the total price of the orders
Customer History Report showing :
- customer name
- month - year
- number of books purchased each month
- monthly expenditure by customer
DAILY REPORT
data:image/s3,"s3://crabby-images/bc355/bc3550b2ab3baaa571081436b93c7d41d39aa8c9" alt=""
data:image/s3,"s3://crabby-images/8b8d8/8b8d82f4f42f9a8c5a4e482f940e7748e88989c8" alt=""
Output
data:image/s3,"s3://crabby-images/2e1ed/2e1edc662911d819a54548483195cfe9b1fcd187" alt=""
I've created a status_updated view to filter the current status of the orders. So this view can be easily used in the following queries.
data:image/s3,"s3://crabby-images/4e015/4e0155922aa7e2ec1928c7aed54a0bf4a11c2b8e" alt=""
ANNUAL REPORT
data:image/s3,"s3://crabby-images/76f10/76f1026c7ab7e8cebdf6b7cafe94ea22377ab661" alt=""
Output
data:image/s3,"s3://crabby-images/aff40/aff40a5a00d831ae0d6f1e67497e63ce6dfb6488" alt=""
CUSTOMER HISTORY REPORT
data:image/s3,"s3://crabby-images/f14d0/f14d0b0cb3de69bb88924c079fa4d0be6433c446" alt=""
Output
data:image/s3,"s3://crabby-images/65580/65580c7beb5e9e3d7ea31c722ae60bf87bd4231e" alt=""