Я знаю, как перечислить все коллекции в конкретной базе данных , но как мне перечислить все доступные базы данных в оболочке MongoDB?
Я знаю, как перечислить все коллекции в конкретной базе данных , но как мне перечислить все доступные базы данных в оболочке MongoDB?
Ответы:
Список всех баз данных в консоли mongoDB использует команду show dbs
.
Для получения дополнительной информации об этом обратитесь к помощникам команд оболочки Mongo, которые можно использовать в оболочке mongo.
db
отображается текущая база данных, test
но это не указано ни в одной из команд на этой странице, что объясняется здесь stackoverflow.com/q/38726310/73226
mongo
в командной строке ( mongo --nodb
чтобы не подключаться к базе данных)
show dbs
такого простого, как, потому что я, когда я шел в документы, я просто не мог найти show dbs
команду нигде. «Документы» иногда могут быть довольно неприятными.
--eval
, только в интерактивной оболочке. Параметры этого ответа работают (хотя формат вывода отличается) stackoverflow.com/a/32192253/1837991
Для оболочки оболочки MongoDB версии 3.0.5 вставьте в нее следующую команду:
db.adminCommand('listDatabases')
или альтернативно:
db.getMongo().getDBNames()
mongo admin --quiet -u <mongodb_admin> -p [<password>] --eval 'db.getMongo().getDBNames().forEach(function(db){print(db)})'
hth
Для списка базы данных:
show databases
show dbs
Для таблицы / списка сбора:
show collections
show tables
db.getCollectionNames()
Из вопроса командной строки
mongo --quiet --eval "printjson(db.adminCommand('listDatabases'))"
который дает вывод
{
"databases" : [
{
"name" : "admin",
"sizeOnDisk" : 978944,
"empty" : false
},
{
"name" : "local",
"sizeOnDisk" : 77824,
"empty" : false
},
{
"name" : "meteor",
"sizeOnDisk" : 778240,
"empty" : false
}
],
"totalSize" : 1835008,
"ok" : 1
}
Чтобы вывести базу данных mongodb на оболочку
show databases //Print a list of all available databases.
show dbs // Print a list of all databases on the server.
Несколько более простых команд
use <db> // Switch current database to <db>. The mongo shell variable db is set to the current database.
show collections //Print a list of all collections for current database.
show users //Print a list of users for current database.
show roles //Print a list of all roles, both user-defined and built-in, for the current database.
Я нашел одно решение, где admin () / другие не работали.
const { promisify } = require('util');
const exec = promisify(require('child_process').exec)
async function test() {
var res = await exec('mongo --eval "db.adminCommand( { listDatabases: 1 }
)" --quiet')
return { res }
}
test()
.then(resp => {
console.log('All dbs', JSON.parse(resp.res.stdout).databases)
})
test()
show dbs
в консоли mongo, просмотритеuseful links
раздел в вики mongodb tag , прежде чем публиковать вопрос, иногда он может помочь вам быстрее найти решение.