Для тех, кто будет писать что в данном посте что-то упущено

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

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

Считается одним из классических примеров NoSQL-систем, использует JSON-подобные документы и схему базы данных. Данную базу данных применяют в веб-разработке, в частности, в рамках JavaScript-ориентированного стека MEAN, MEVN, MERN, которые часто используются веб-разработчиками, как любимые стеки технологий для создания приложений.

Установка

Скачать MongoDB можно с официального сайта для Linux, MacOS, Windows.

В Linux это также можно сделать с одной из следующих команд:

apt

sudo apt install -y mongodb

dnf

cat <<EOF | sudo tee /etc/yum.repos.d/mongodb.repo
[mongodb-org-4.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/7/mongodb-org/4.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.4.asc
EOF

sudo yum install -y mongodb-org

brew

brew tap mongodb/brew
brew install mongodb-community

Также для того чтобы взаимодействовать с БД нам потребуется шелл (MongoShell), который качается отдельно: https://www.mongodb.com/try/download/shell?jmp=docs

Основы

После успешной установки MongoDB и Mongoshell мы можем спокойно начать взаимодействовать с базой данных с помощью терминала. Достаточно просто ввести mongosh:

Как мы видим мы находимся в базе данных test, однако на самом деле её пока что не существует!

Более подробно о том, что будет ниже можно прочитать здесь

Всё дело в том, что в mongoDB не существует базы данных, покуда мы в неё что-то не поместим. Также, при обращении к определенным объектам (база данных, коллекция) mongoDB они меняют значение, только если существуют, а если не существуют, то они просто создаются. Давайте продемонстрируем принцип работы:

show dbs

Команда show dbs показывает какие базы данных существуют в данный момент. Как мы видим в списке нет значения test.

Для того чтобы создать новую базу данных (или использовать существующую) мы должны использовать ключевое слово use:

use new_database

Как мы видим мы перешли в базу данных new_database, однако в списке мы её не наблюдаем (это из-за того правила, что я писал вверху: базы данных не существует, покуда неё что-то не поместить).

Давайте создадим новую коллекцию под названием customers (покупатели) и положим туда значение name: Daniil:

db.customers.insertOne({name: "Daniil"});

Тут мы обратились к базе данных с помощью db, затем мы указали коллекцию через точку и положили туда значение с помощью функции insertOne(). JavaScript является языком запросов MongoDB. Под капотом MongoDB находится MozJs, который является форком SpiderMonkey (Mozilla Firefox).Если вам интересно, вы можете взглянуть на исходный код.

Теперь давайте посмотрим какие коллекции есть в нашей базе данных, но как это сделать? Можно ввести db. и нажать Tab, для того чтобы посмотреть какие свойства и методы есть у нашего объекта db (объектом для легкости понимания можно считать обычный объект из JavaScript, тут даже методы есть похожие: toString, isPrototypeOf, hasOwnProperty)

Далее мы можем посмотреть наши коллекции с помощью специального метода getCollectionNames:

db.getCollectionNames();

Вуаля! У нас есть массив из наших коллекций и по такому же принципу (нахождения нужных нам методов) можно исследовать всю MongoDB, однако мне ещё есть что рассказать, продолжим.

Есть ещё сокращения команд, которые мы тоже можем использовать, например show collections вернёт нам то же самое, однако вид будет более читаемый для человека:

show collections

У нашей коллекции, к слову, тоже есть методы и свойства, но они немного другие:

Мы можем использовать коллекцию в связке с find(), для того чтобы вывести всё содержимое коллекции:

db.customers.find();

Давайте добавим ещё нескольких покупателей с помощью метода insertMany():

db.customers.insertMany([{name: "Jinx"}, {name: "Tony"}, {name: "Alex"}]);

Итак, давайте заметим несколько моментов на скриншоте:

  1. Метод insertMany() принимает массив элементов, а не просто элементы

  2. MongoDB все равно прилегают ли ключи и их значения к скобкам или нет

  3. Синтаксис MongoDB очень похож на синтаксис JavaScript, поэтому мы можем использовать все виды кавычек (двойные, одинарные, обратные).

В ответ данный метод отдал нам объект, в котором есть свойство acknowledged (подробнее читайте тут) и вложенный объект с ключами из массива и соответствующими им id.

Теперь давайте выведем двух пользователей (не важно каких) из нашего списка используем следующую команду db.customers.find().limit(2):

Как мы видим мы вывели всего два объекта из нашей коллекции, однако что ещё мы можем делать с "найденными" объектами? А вот что:

У метода есть свои методы и мы как и в JavaScript можем цеплять методы один за другим, для того чтобы провести результат который отдал один метод через следующий, идущий за ним через ..

Теперь давайте рассортируем наши значения с помощью метода sort():

Метод sort() принимает в аргументы объект, где указано по какому значению нужно провести сортировку. 1 говорит о том, что сортировку нужно произвести в порядке возрастания, -1 же будет производить её в порядке убывания.

Можно сортировать значения и с помощью двух аргументов, но для начала давайте их добавим! Для того чтобы добавить значения к найденному элементу коллекции давайте применим функцию updateOne:

db.customers.updateOne({name: "Daniil"}, {$set: {age: 19}});

Необычное ключевое слово $set, которое вы видите на скриншоте является атомным оператором, о нём мы поговорим попозже. Главное что стоит сейчас увидеть - то что мы поменяли значение, а $set просто указывает новые значения в нашей записи.

Теперь давайте применим метод updateMany() для того чтобы поменять значения у множества элементов, а затем перейдем к сортировке с двумя аргументами:

db.customers.updateMany({name: {$ne: "Daniil"}}, {$set: {age: 15}});

Появился ещё один атомный оператор, который обозначает не равно (ne - not equal). В данном случае запрос звучит так: "Найди мне все записи, где имя не равно 'Daniil', и поставь им значение 'age' в 15". (Для справки: set (англ.) - назначить, поставить)

Теперь рассортируем массив с помощью двух аргументов:

db.customers.find().sort({age: -1, name: -1});

Тут sort() принял аргументом объект с двумя ключами. Сначала он будет сортировать записи по первому ключу, а если найдет повторяющиеся первые ключи, то начнёт сортировать по второму ключу. -1 означает обратную сортировку (в порядке убывания).

MongoDB позволяет получить специфические поля из найденных объектов и не показывать другие (нам ненужные поля):

db.customers.find({}, {name: 1, _id: 0});

Здесь мы просто наши все записи с помощью {} (так как определенного идентификатора для нахождения не задано, mongoDB вернул нам все записи), а вторым аргументом передали что именно хотим видеть. 1 тут соответствует выводу, а 0 - наоборот, те данные, которые не будут выводиться.

Также мы можем выводить наши значения и с помощью других методов, однако дочерние методы тоже будут другими:

db.customers.aggregate();
db.customers.aggregate().toArray();

В данном случае мы перевели наш массив данных в обычный массив. Позже мы сможем проводить над ним некие операции.

Более сложные запросы

Атомные операторы нужны для того, чтобы усложнять запросы. Популярные атомные операторы:

  • gt - greater than (больше)

  • lt - less than (меньше)

  • gte и lte - больше или равно и меньше или равно

  • eq - равно

  • ne - не равно

  • in - значение содержится в чем-то

  • nin - значение не содержится в чем-то

  • or - или

  • and - и

  • exists - существует

  • set - изменить или добавить

Некоторые из них мы рассмотрим ниже:

db.customers.find({age: {$gt: 15}});

Как мы видим тут вывелись все записи, у которых поле age больше чем 15.

db.customers.find({name: {$in: ['Daniil', 'Jinx']}});

Тут же вывелись все записи, у которых имя содержится в массиве ['Daniil', 'Jinx'] .

Добавим ещё один объект, у которого не будет поля age и проверим работу оператора exists:

db.customers.find({age: {$exists: true}});

Видим, что тут exists отработал верно и запись с name: 'Denis' не вывелась.

Стоит уточнить, что атомные операторы работают почти со всеми командами в MongoDB, вы можете совмещать их и создавать сложные запросы.

Все остальные команды по типу:

  • deleteOne (удаляет запись)

  • replaceOne (заменяет запись)

  • updateOne (обновляет запись)

и их братья-близнецы с Many работают точно так же. Вы можете попробовать узнать зачем они нужны просто создав базу данных с парой записей и поэксперементировать (в конце-концов так материал будет усваиваться достаточно быстро и осядет в вашей голове на долгое время), ведь всё что вам нужно вы уже узнали.

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

Комментарии (4)


  1. hello_my_name_is_dany
    29.09.2021 21:03
    +6

    Картинки, конечно, легко делать, но почему не просто код?

    А если по существу, то JavaScript и является языком запросов MongoDB. Там под капотом MozJs, который является форком SpiderMonkey (Mozilla FireFox). Прежде чем предполагать, зачастую можно посмотреть исходный код


    1. daniil-dev Автор
      29.09.2021 22:17

      Спасибо за замечание. Сейчас добавлю.


  1. Svetafo
    29.09.2021 23:04
    +5

    Почему скриншоты, а не сниппеты кода? Почему MongoDB мужского рода? Какой-то поспешный и небрежный текст получился, а задумка с первыми шагами для новичков хорошая


  1. saboteur_kiev
    30.09.2021 03:01
    +3

    Картинки. Мелкие. Скопировать-вставить нельзя.
    Просто базовая документация по монге, только плохо видно?