Командная строка MongoDB
"Склерозник" по основным командам MongoDB.
MongoDB — документоориентированная система управления базами данных с открытым исходным кодом, не требующая описания схемы таблиц. Классифицирована как NoSQL, использует JSON-подобные документы и схему базы данных.
Запуск клиента:
sudo mongo
Список баз:
show dbs
Использовать базу (demo — имя базы):
use demo
Список collections:
show collections
Добавить пользователя в админы со всеми правами:
use admin
db.createUser({user:"root", pwd:"root", roles:[ "root"]})
Или с указанием ролей:
db.createUser({user:"admin", pwd:"password", roles:[ "userAdminAnyDatabase", "dbAdminAnyDatabase", "readWriteAnyDatabase"]})
db.createUser({user:"admin", pwd:"password", roles:[ "dbOwner" ]})
Аутентифицироваться с командной строки:
sudo mongo -u root -p root --authenticationDatabase admin
sudo mongo -u admin -p admin --authenticationDatabase test
Системная информация о базе:
db.stats()
Системная информация о collections:
db.test.stats()
Список индексов в collection:
db.test.getIndexes()
Вставка документа в collection users:
db.users.insert({"name":"username"})
Выборка по условю (По одному полю):
db.test.find({"name":"Andre"})
Выборка по условию (И):
db.test.find({"name":"Andre","id":"2"})
Выборка по условию (Больше):
db.numbers.find({num:{"$gt": 60000}})
Выборка по условию (В диапазоне):
db.numbers.find({num:{"$gt": 60000, "$lt": 60010}})
Обновление записи:
db.test.update({"_id":ObjectId("5aae3be1b371d7112a438547")}, {$set: {name:"Patya", id:3}})
db.users.update( { "favorites.movies": "Casblanca"},
{$addtoSet: {"favorites.movies": "The Maltese Falcon"} },
false,
true )
Четвертый параметр true - говорит, что это множественное обновление. По умолчанию MongoDB обновит только первую запись подходящую по условию.
Обновление документа (SAVE) если нет поля _id, тогда будет создан новый документ:
db.test.save({"_id":ObjectId("5aae3be1b371d7112a438547")}, {$set: {name:"Patya", id:3}})
Удаление документов:
db.test.remove({"_id":ObjectId("5aae3be1b371d7112a438547")})
Подсчет кол-ва документов:
db.numbers.count()
Удалить коллекцию со всеми данными и индексами:
db.test.drop()
Запрос с выводом информации о выполнении для дальнейшего анализа:
db.numbers.find({num:{"$gt": 60000}}).explain("executionStats")
Создать индекс по полю num по возрастанию:
db.numbers.ensureIndex({num: 1})
Експорт / Импорт
Експорт (mongoexport) в JSON, CSV, TSV:
mongoexport --host=127.0.0.1 --port=27017 --db=test --collection=test --type=json --out=test_test.json --jsonArray --pretty
Импорт (mongoimport) из JSON, CSV, TSV
mongoimport --host=127.0.0.1 --port=27017 --db=test --collection=test --file=test_test.json --type=json --jsonArray
Информация и статистика
mongostat
Удачи.
Дивись також:
- Справочник команд по Docker. Как поднять Swarm
- MongoDB Replica Set в Docker
- Справочник команд MongoDB
- Как настроить NGNIX Loader balancer + SSL в Docker
- Технология Push notifications. Как сделать на сайте
- Пример Websocket сервера и Websocket клиента. Пример простого чата на websocket
- Как использовать Memcached в Python
- Как использовать Radis в Python
Недавні записи
- Модуль драйверів напівмосту IGBT транзисторів
- Драйвер IGBT транзисторів на A316J
- AS5600. Варіант встановлення на BLDC мотор
- DC-DC для IGBT драйверів ізольований 2 W +15 -8 вольт
- U-FOC - Векторне керування безколекторними моторами
- FOC - своя реалізація векторного керування. Підбиваю підсумки 2022 року
- Конструктор регуляторів моторів. Підбиваю підсумки 2022 року.
- Чому трифазні мотори стали такими популярними?
- FOC & Polar coordinates
- Конструктор регуляторів PMSM, BLDC двигунів
Tags
ngnix avr brushless motor examples dma books lcd usb dht11 piezo led servo web pmsm esp8266 ssd1331 wifi bme280 mpu-9250 capture hih-4000 bldc programmator rs-232 ethernet docker dc-dc sms bkp stm32 css git uart meteo bmp280 3d-printer displays mpx4115a eeprom max1674 soldering atmega timer gps tim flash nvic html java-script pwm solar rfid nodemcu st-link options watchdog adc gpio battery bluetooth raspberry-pi python websocket usart foc mongodb flask mpu-6050 barometer exti smd ssd1306 i2c sensors remap rtc encoder eb-500
Архіви