- Joins
- Database Queries
- Knex Queries
- Modular Code
For this lab you will
- write SQL statements against the
northwind.db3
database. Once you have the correct SQL Statement for each query, write it inside the queries.sql file under the corresponding comment. - write the db helper methods for the
schemes
resource in./schemes/scheme-model.js
Use a graphical tool like SQLite Studio
to open ./data/northwind.db3
and execute the following queries:
-
Display the ProductName and CategoryName for all products in the database. Returns 77 records.
SELECT Product.ProductName, Category.CategoryName FROM Product JOIN Category ON Product.CategoryId = Category.Id;
-
Display the order Id and shipper CompanyName for all orders placed before August 9 2012. Returns 429 records.
SELECT Id, OrderDate, s.CompanyName FROM [Order] JOIN [Shipper] as s ON s.Id = [Order].ShipVia WHERE OrderDate < '2012-08-09' ORDER by OrderDate;
-
Display the name and quantity of the products ordered in order with Id 10251. Sort by ProductName. Returns 3 records.
SELECT d.Quantity, p.ProductName FROM [OrderDetail] as d join [Product] as p on p.id = d.ProductId where d.OrderId = '10251' order by p.ProductName
-
Display the OrderID, customer's Company Name and the employee's Last Name for every order. All columns should be labeled clearly. Returns 16,789 records.
SELECT distinct od.OrderId, c.CompanyName, e.LastName FROM [OrderDetail] as od JOIN [Order] as o on od.OrderId = o.id JOIN [Customer] as c on o.CustomerId = c.id JOIN [Employee] as e on o.EmployeeId = e.id;
Write helpers methods in ./schemes/scheme-model.js
that match the following specifications:
find()
:- Calling find returns a promise that resolves to an array of all schemes in the database.
- No steps are included.
findById(id)
:- Expects a scheme
id
as its only parameter. - Resolve to a single scheme object.
- On an invalid
id
, resolves tonull
.
- Expects a scheme
findSteps(id)
:- Expects a scheme
id
. - Resolves to an array of all correctly ordered step for the given scheme:
[ { id: 17, scheme_name: 'Find the Holy Grail', step_number: 1, instructions: 'quest'}, { id: 18, scheme_name: 'Find the Holy Grail', step_number: 2, instructions: '...and quest'}, etc. ]
. - This array should include the
scheme_name
not thescheme_id
.
- Expects a scheme
add(scheme)
:- Expects a scheme object.
- Inserts scheme into the database.
- Resolves to the newly inserted scheme, including
id
.
update(changes, id)
:- Expects a changes object and an
id
. - Updates the scheme with the given id.
- Resolves to the newly updated scheme object.
- Expects a changes object and an
remove(id)
:- Removes the scheme object with the provided id.
- Resolves to the removed scheme
- Resolves to
null
on an invalid id. - (Hint: Only worry about removing the
scheme
. The database is configured to automatically remove all associated steps.)
field | data type | metadata |
---|---|---|
id | unsigned integer | primary key, auto-increments, generated by database |
scheme_name | string | required, unique |
field | data type | metadata |
---|---|---|
id | unsigned integer | primary key, auto-increments, generated by database |
scheme_id | unsigned integer | foreign key referencing scheme.id, required |
step_number | unsigned integer | required |
instructions | string | required |
The following endpoints are available to test the functionality of the model methods.
GET /api/schemes/
- gets master list of schemes (without steps)GET /api/schemes/:id
- gets a single schemeGET /api/schemes/:id/steps
- gets all steps for a given scheme, ordered correctlyPOST /api/schemes
- adds a new schemePUT /api/schemes:id
- updates a given schemeDELETE /api/schemes/:id
- removes a given scheme and all associated steps
- In SQL Try Editor at W3Schools.com:
- Displays CategoryName and a new column called Count that shows how many products are in each category. Shows 8 records.
- Display OrderID and a column called ItemCount that shows the total number of products placed on the order. Shows 196 records.
- Add the following method to your API
addStep(step, scheme_id)
: This method expects a step object and a scheme id. It inserts the new step into the database, correctly linking it to the intended scheme.- You may use
POST /api/schemes/:id/addStep
to test this method.