Analysing Book Store Sample Data with PostgreSQL
Writing complex SQL queries
data:image/s3,"s3://crabby-images/01b9d/01b9deba6824bc023f8c4a4ca070906a395343eb" 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/8c6a6/8c6a6986c90e91cc75264212d36f8c0476fb9ee6" alt=""
data:image/s3,"s3://crabby-images/fea8b/fea8b769ea060995ee9402ad6cda93a934f9cb22" alt=""
Output
data:image/s3,"s3://crabby-images/8bf36/8bf36f13272fa45be1a126b835fc3901cdaefe16" 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/a971b/a971b5efc324526d813948ce1122687622aff801" alt=""
ANNUAL REPORT
data:image/s3,"s3://crabby-images/c7eb4/c7eb42b46e784156793a13dd8254f1057ff568b6" alt=""
Output
data:image/s3,"s3://crabby-images/d8a78/d8a789a78a8d0e89079791cf08925d552c640ef9" alt=""
CUSTOMER HISTORY REPORT
data:image/s3,"s3://crabby-images/1a8af/1a8afc0a7a362960a2d839df601f9b488dc02557" alt=""
Output
data:image/s3,"s3://crabby-images/5ec48/5ec483caa55dfaa5e8a3e3ad865f6d24c453da33" alt=""