Подтвердить что ты не робот

MongoDB: Получение списка всех баз данных?

Как мне перечислить все базы данных для подключения с помощью драйвера Mongo С#?

4b9b3361

Ответ 1

Очень легко:

var server = MongoServer.Create("mongodb://localhost/?safe=true");
var databaseNames = server.GetDatabaseNames();

Ответ 2

Класс MongoServer устарел в версии 2.0.0.

Вы можете использовать ListDatabasesAsync

using (var cursor = await client.ListDatabasesAsync())
{
    await cursor.ForEachAsync(d => Console.WriteLine(d.ToString()));
}

Ответ 3

Рабочее решение:

MongoClient client = new MongoClient("mongodb://localhost:27017");
using (IAsyncCursor<BsonDocument> cursor = client.ListDatabases())
{
    while (cursor.MoveNext())
    {
        foreach (var doc in cursor.Current)
        {
            Console.WriteLine(doc["name"]); // database name
        }
    }
}

Ответ 4

Класс MongoServer устарел в версии 2.0.0, как указал Юри. Если вы не хотите использовать async, вот как я это делаю:

var client = new MongoClient("mongodb://" + server_username + ":" + server_password + "@" + server_host + ":" +  server_port);

List<MongoDB.Bson.BsonDocument> databases = client.ListDatabases();

Только одно. Он находится в формате BsonDocument, который имеет 2 элемента: "имя" и "размерOnDisk".

Надеюсь, что это поможет.

Ответ 5

Я не смог проверить, существует ли конкретная БД или нет с существующими ответами, поэтому здесь я беру ее на себя:

    // extension method on IMongoClient
    public static IMongoClient AssertDbExists(this IMongoClient client, string dbName)
    {
        bool dbFound = false;

        using(var cursor = client.ListDatabases())
        {
            var databaseDocuments = cursor.ToList();
            foreach (var db in databaseDocuments)
            {
                if (db["name"].ToString().Equals(dbName))
                {
                    dbFound = true;
                    break;
                }
            }
        }

        if (!dbFound) throw new ArgumentException("Can't connect to a specific database with the information provided", nameof(MongoSettings.ConnectionString));

        return client;
    }

И затем используйте его следующим образом:

// either you get the client with the DB validated or throws
_client = new MongoClient(settings.ConnectionString).AssertDbExists(_dbName);

Использование: Официальный драйвер Mongo С# v.2.4.4