MongoDB отбросить каждую базу данных - PullRequest
82 голосов
/ 16 июня 2011

Я хотел бы знать, есть ли команда для удаления всех баз данных из моего MongoDB?

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

mongo DB_NAME --eval 'db.dropDatabase();'

Ответы [ 8 ]

130 голосов
/ 17 июня 2011

Вы можете создать цикл javascript, который выполняет эту работу, а затем выполнить ее в mongoconsole.

var dbs = db.getMongo().getDBNames()
for(var i in dbs){
    db = db.getMongo().getDB( dbs[i] );
    print( "dropping db " + db.getName() );
    db.dropDatabase();
}

сохранить его в dropall.js и затем выполнить:

mongo dropall.js
88 голосов
/ 04 июня 2013

Попробуйте эту команду:

mongo --quiet --eval 'db.getMongo().getDBNames().forEach(function(i){db.getSiblingDB(i).dropDatabase()})'
17 голосов
/ 20 июня 2012

Вы также можете сделать это с помощью простой команды монго:

db.adminCommand("listDatabases").databases.forEach( function (d) {
    if (d.name != "local" && d.name != "admin"  && d.name != "apiomat"  && d.name != "config")
        db.getSiblingDB(d.name).dropDatabase();
 })
5 голосов
/ 09 февраля 2013

Добавляя к ответу @ ALoR, для удобства вы можете поместить следующее в ~ / .mongorc.js

function dropDatabases(){
    var mongo = db.getMongo();

    var dbNames = mongo.getDBNames();
    for (var i = 0; i < dbNames.length; i++) {
        var db = mongo.getDB( dbNames[i] );

        print( "Dropping database " + db.getName() + "..." );
        db.dropDatabase();
    }
}

Тогда в оболочке Монго вы можете просто сделать

dropDatabases()

Из документов:

Mongo будет читать файл .mongorc.js из домашнего каталога пользователя, вызывающего mongo. В этом файле пользователи могут определять переменные, настраивать приглашение оболочки mongo или обновлять информацию, которую они хотели бы обновлять при каждом запуске оболочки.

4 голосов
/ 03 мая 2017

Сохраните это в drop_all_dbs.js:

var databases = db.getMongo().getDBNames()
for(var i in databases){
    db = db.getMongo().getDB( databases[i] );
    if(db.getName() == "admin" || db.getName() == "local"){
        print("skipping db " + db.getName())
        continue
    }
    print( "dropping db " + db.getName() );
    db.dropDatabase();
}

Теперь вы можете выполнить:

mongo drop_all_dbs.js

и все базы данных (кроме административных и локальных) будут удалены.

Этот ответ является копией ALoR, просто исправьте падение системных dbs

4 голосов
/ 16 июня 2011

Вы можете сделать это легко через официальный драйвер c #:

var _mongoServer = MongoServer.Create("mongodb://localhost:27020");

var names = _mongoServer.GetDatabaseNames();
foreach (var name in names)
{
   _mongoServer.DropDatabase(name);
}
1 голос
/ 24 апреля 2019

var mongo = db.getMongo(); mongo.getDBNames().filter(n => n != 'admin' && n != 'local' && n != 'config').forEach(function (dbname) { var db = mongo.getDB(dbname); db.dropDatabase(); });

Это безопасно копировать и выполнять на mongoshell. Кредиты на все ответы выше. Просто исключите базу данных 'config'.

0 голосов
/ 12 июня 2018

Это так же просто, как

mongo --eval 'db.dropDatabase()'

Или вы можете запустить сеанс монго на своем терминале и написать

db.dropDatabase()

Что точно так же.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...