Учебник по основам MongoDB

MongoDB - это база данных, часть приложения, отвечающая за хранение и получение информации.

MongoDB - это база данных NoSQL. ПодNoSQLЗонтик мы помещаем все те базы данных, которые не используют язык SQL для запроса данных.

Ключевые характеристики MongoDB

MongoDB - очень дружественная к JavaScript база данных. Он предоставляет JavaScript API, который мы можем использовать для создания баз данных и коллекций объектов (называемыхдокументы).

Этобессмысленный, что означает, что вам не нужно заранее определять структуру данных перед их сохранением.

В MongoDB вы можете хранить любой объект, не беспокоясь о конкретных полях, составляющих этот объект, и о том, как их хранить. Вы говорите MongoDB сохранить этот объект.

Данные хранятся в формате, аналогичном JSON, но улучшенном, чтобы можно было хранить больше, чем просто базовые типы данных.

Установка

Давайте продолжим и установим MongoDB. Вы можете использовать одного из многих облачных провайдеров, которые предлагают доступ к экземпляру MongoDB, но ради обучения мы установим его сами.

Я использую Mac, поэтому инструкции по установке в этом руководстве относятся к этой операционной системе.

Откройте терминал и запустите:

brew tap mongodb/brew
brew install mongodb-community

Вот и все.

Инструкции не были слишком длинными и сложными, если вы знаете, как пользоваться терминалом икак установить Homebrew.

Установка сообщает нам следующее:

To have launchd start mongodb now and restart at login:
  brew services start mongodb-community
Or, if you don't want/need a background service you can just run:
  mongod --config /usr/local/etc/mongod.conf

You can choose to either launch MongoDB once and have it running forever as a background service in your computer (the thing I prefer), or you can run it just when you need it, by running the latter command.

The default configuration for MongoDB is this:

systemLog:
  destination: file
  path: /usr/local/var/log/mongodb/mongo.log
  logAppend: true
storage:
  dbPath: /usr/local/var/mongodb
net:
  bindIp: 127.0.0.1

Logs are stored in /usr/local/var/log/mongodb/mongo.log and the database is stored in /usr/local/var/mongodb.

By default there is no access control, anyone can read and write to the database.

The Mongo Shell

The best way to experiment with MongoDB and starting to interact with it is by running the mongo program, which starts the MongoDB shell.

You can now enter any command that Mongo understands.

Create a database

When you start, Mongo creates a database called test. Run db in the shell to tell you the name of the active database

To change the database, just write use newname and the newname database will be instantly created and the shell switches to using that.

Use show databases to list the available databases:

As you can see, the something database is not listed, just because there is no collection yet in it. Let’s create one.

Collections

In MongoDB, a collection is the equivalent of a SQL database table.

You create a collection on the current database by using the db.createCollection() command. The first argument is the database name, and you can pass an options object as a second parameter.

Once you do so, show databases will list the new database, and show collections will list the collection.

You can also create a new collection by using it as a property of the db object, and calling insert() to add an object to the collection:

db.dogs.insert({ name: 'Roger' })

Listing objects in a collection

To show the objects added to a collection, use the find() method:

As you can see there is an additional _id property for the record we added. That’s automatically generated for us by MongoDB.

Now, add more dogs:

db.dogs.insert({ name: 'Buck' })
db.dogs.insert({ name: 'Togo' })
db.dogs.insert({ name: 'Balto' })

Calling db.dogs.find() will give us all the entries, while we can pass a parameter to filter and retrieve a specific entry, for example with db.dogs.find({name: 'Roger'}):

The find() method returns a cursor you need to iterate on.

There is another method which is handy when you know you’ll only get one record, which is findOne(), and it’s used in the same way. If multiple records match a query, it will just return the first one.

Updating records

To update a record you can use the update() method on a collection:

Removing records

You can remove a record calling the remove() method on a collection, passing an object to help identify it:

To remove all the entries from a collection, pass an empty object:

db.dogs.remove({})

More database tutorials: