From 4b2ab6097c1cdb4f8800fa8bd1c25053961f4451 Mon Sep 17 00:00:00 2001 From: Chidimma Date: Sat, 14 Jan 2023 18:07:31 +0000 Subject: [PATCH] week 1 assignment completed --- week-1/mandatory/2-classes-db/task.md | 34 +++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/week-1/mandatory/2-classes-db/task.md b/week-1/mandatory/2-classes-db/task.md index 735de6ae..bf0582b0 100644 --- a/week-1/mandatory/2-classes-db/task.md +++ b/week-1/mandatory/2-classes-db/task.md @@ -2,7 +2,7 @@ ## Submission -Below you will find a set of tasks for you to complete to consolidate and extend your learning from this week. You will find it beneficial to complete the reading tasks before attempting some of these. +Below you will find a set of tasks for you to complete to consolidate and extend your learning from this week. You will find it beneficial to complete the reading tasks before attempting some of these. To submit this homework write the correct commands for each question here: @@ -18,19 +18,49 @@ When you have finished all of the questions - open a pull request with your answ If you haven't completed all the exercises from this lesson then do that first. ### Tasks + 1. Which rooms have a rate of more than 100.00? + Ans: select room_no from rooms where rate > 100; + 2. List the reservations that have a checkin date this month and are for more than three nights. + Ans: select * from reservations where (checkIn_date between '2023-01-01'and '2023-01-31') and (checkOut_date - checkIn_date > 3); + 3. List all customers from cities that begin with the letter 'M'. + Ans: select name, city from customers where city like 'M%'; Insert some new data into the room_types and rooms tables, querying after each stage to check the data, as follows: 4. Make a new room type of PENTHOUSE with a default rate of £185.00 + Ans: insert into room_types (room_type, def_rate) values ('PENTHOUSE', '185.00'); + 5. Add new rooms, 501 and 502 as room type PENTHOUSE and set the room rate of each to the default value (as in the new room type). + Ans: insert into rooms (room_no, rate, room_type) values ('501', '185.00', 'PENTHOUSE'); + insert into rooms (room_no, rate, room_type) values ('502', '185.00', 'PENTHOUSE'); + 6. Add a new room 503 as a PREMIER PLUS type similar to the other PREMIER PLUS rooms in the hotel but with a room rate of 143.00 to reflect its improved views over the city. + Ans: insert into rooms (room_no, rate, room_type) values ('503', '143.00', 'PREMIER PLUS'); Using what you can learn about aggregate functions in the w3schools SQL classes (or other providers), try: 7. The hotel manager wishes to know how many rooms were occupied any time during the previous month - find that information. + Ans - 106 - select count(id) from reservations; + NB: some room_no data where missing, hence the choice of id. + 8. Get the total number of nights that customers stayed in rooms on the second floor (rooms 201 - 299). + Ans: 63 + query: select sum(checkOut_date -checkIn_date) as total_nights from reservations where room_no between 200 and 299; + 9. How many invoices are for more than £300.00 and what is their grand total and average amount? -10. Bonus Question: list the number of nights stay for each floor of the hotel (floor no is the hundreds part of room number, e.g. room **3**12 is on floor **3**) + + Ans: 25 invoices - select count(total) from invoices where total > 300; + Grand total : 12928.00 - select sum(total) from invoices where total > 300; + Average: 517.12 - select avg(total) from invoices where total > 300; + +10. Bonus Question: list the number of nights stay for each floor of the hotel (floor no is the hundreds part of room number, e.g. room **3**12 is on floor **3**) + Floor 1: 54 - select sum(checkOut_date -checkIn_date) from reservations where room_no between 100 and 199; + + Floor 2: 63 - select sum(checkOut_date -checkIn_date) from reservations where room_no between 200 and 299; + + Floor 3: 46- select sum(checkOut_date -checkIn_date) from reservations where room_no between 300 and 399; + + Floor 4: 40 - select sum(checkOut_date -checkIn_date) from reservations where room_no between 400 and 499;