Day 15: Models - Adding a Database with Mongoose
Reminders for Tony
- Put on mic
- Open Zoom chat
- Record! Anyone else?
Topics Covered
- Introduction to CRUD and Mongoose
- Search: SQL vs NoSQL
- Search: mongoose crud
- Mongoose CRUD (Create, Read, Update, Delete)
- Mongoose Models
- If we have time: Exploring Mongoose CRUD operations
Goal for the day
By the end of the day, you should have a Destinations model defined in your app using Mongoose. It will be connected to your cloud-hosted Atlas Mongo database.
Important! DO NOT push your connection code to a public repository until you learn about environment variables below. Either don’t push today’s code to Github or make your repository private.
Topic 1: Introduction to CRUD
When we are building APIs, we want our models to provide four basic types of functionality. The model must be able to Create, Read, Update, and Delete resources. Computer scientists often refer to these functions by the acronym CRUD. A model should have the ability to perform at most these four functions in order to be complete. If an action cannot be described by one of these four operations, then it should potentially be a model of its own.
Activity objectives: Setup MongoDB Atlas/Compass
Follow the steps listed in this article: Using Express with MongoDB Atlas
Rename .env-sample You’ve been given a sample environment file named .env-sample
. You’ll need to rename it to .env
in order for the dotenv
module to find it and import it into your app.
You will need to install two additional Node modules:
$ npm install dotenv
$ npm install mongoose
When you have completed the steps in the linked tutorial, your .env
file should look something like this:
MONGODB_URL=mongodb+srv://kitten:hello-kitten@cluster0-1c2nl.mongodb.net/animals?retryWrites=true&w=majority
PORT=3000
Variable Name Suggestion: The above tutorial instructs you (at “Get Connection URI String”) to use an environment name of MONGO_URI
. Instead, use MONGODB_URL
since this is what Heroku uses when you deploy your website later in the course.
MongoDB Connection String The connection string that you copy and paste from the Connection window in MongoDB Atlas contains <
and >
characters. Be sure to remove those when you enter your DB name, username & password.
Common Connection Error The 'uri' parameter to 'openUri()' must be a string, got 'undefined'
error usually means your application is not reading your environment variable correctly. Double check your connection string, variable names and that your environment file is named .env
.
Topic 2: Mongoose models
For the your Travel Experts project we’re going to use the Mongoose ODM to access our library data. Mongoose acts as a front end to MongoDB, an open source NoSQL database that uses a document-oriented data model. A “collection” of “documents” in a MongoDB database is analogous to a “table” of “rows” in a relational database.
This ODM and database combination is extremely popular in the Node community, partially because the document storage and query system looks very much like JSON, and is hence familiar to JavaScript developers.
Mid-day Huddle
- who needs help?
- any pivots?
- any show-and-tell?
[lunch]
Activity objectives: Seed database with starting data
In today’s sample code folder you will find a _build.js
file that will insert our “seed data”.
- Navigate to
/sample-code/backend/5-animals-mongoose
in your terminal. - Ensure that you have a .env file with your MongoDB Atlas connection string. Note the database that you’ll be connecting to (before the “?”).
-
Run the build script to import your seed data into your Atlas database.
$ node _build.js
-
You should see a new collection in your Atlas control panel. The name will be the plural version of the name you gave your compiled model. For example, the collection name for the animals sample site is “Animals” because the model was compiled with the name “Animal”:
module.exports = mongoose.model('Animal', gallerySchema);
Topic 3: Exploring Mongoose CRUD operations
If we have time at the end of the day, we’ll run through some CRUD examples using Mongoose.
Activity objectives: Migrate Travel Experts to Atlas
Now that you have a populated database to connect to, it’s time to refactor your Travel Experts website to use your new Mongoose model.
- Refactor
GET /
to usemodel.findOne()
; - Refactor
GET /api/destinations
to usemodel.find()
.
Summary
- any trophies?
- prep for tomorrow?
- applause