MongoDB installs with a client app, a JavaScript-based shell, that allows us to interact with MongoDB directly.
Open a new terminal window and start a mongo shell by typing mongo
.
The app will load and change the prompt will change to >
.
List the shell's commands available: > help
.
Show the list of databases: > show dbs
.
Show the name of the currently active database: > db
.
Switch to a different database: > use [name of database to switch to]
.
Lets switch to the local
database: > use local
.
Show the collections of the current database > show collections
.
To create a new database in the Mongo Shell, we simply have to use the database. Lets create a database named myDB:
> use myDB
This how we can create and insert a document into a collection named people:
> db.people.insert({
name: "Fred",
age: 21
})
Using a collection for the first time creates it!
In a moment we'll practice querying our database, but let's get more data in there. Here are few more documents to put in your people collection. We can simply provide this array to the insert method and it will create a document for each object in the array.
db.people.insert(
[
{
"name": "Emma",
"age": 20
},
{
"name": "Ray",
"age": 45
},
{
"name": "Celeste",
"age": 33
},
{
"name": "Stacy",
"age": 53
},
{
"name": "Katie",
"age": 24
},
{
"name": "Adrian",
"age": 47
}
])
To list all documents in a collection, we use the find method on the collection without any arguments:
> db.people.find()
Again, unlike the rows in a relational database, our documents don't have to have the same fields!
We can also use the find()
method to query the collection by passing in an argument – a JS object containing criteria to query with.
> db.people.find({name: "Adrian"})
There are a handful of special criteria variables we can use, too. Here's how we can use MongoDB's $gt
query operator to return all people documents with an age greater than 20:
> db.people.find({age: { $gt: 20}})
MongoDB comes with a slew of built-in query operators we can use to write complex queries.
How would we write a query to retrieve people that are less than or equal to age 24?
This sorts our age query and sorts by name:
> db.people.find({age: {$gt: 20}}).sort({name: 1})
The "1" indicates ascending order.
This documentation provides more detail about reading data.
In MongoDB, we use the update()
method of collections by specifying the update criteria (like we did with find()
), and use the $set
action to set the new value.
> db.people.update({name: "Adrian"}, {$set: { age: 99 } })
By default update()
will only modify a single document. However, with the multi
option, we can update all of the documents that match the query.
> db.people.update( { name: { $lt: "M" } }, { $inc: { age: 10 } }, { multi: true } )
We used the $inc
update operator to increase the existing value.
Here is the list of Update Operators available.
We use the remove()
method to data from collections.
If you want to completely remove a collection, including all of its indexes, use db.[name of the collection].drop()
.
Call remove({})
on the collection to remove all docs from a collection. Note: all documents will match the "empty" criteria.
Otherwise, specify a criteria to remove all documents that match it:
>db.people.remove( { age: { $lt: 16 } } )