在Npgsql中获取数据库列表
本文关键字:数据库 列表 获取 Npgsql | 更新日期: 2023-09-27 18:20:57
如何使用C#
中的Npgsql
获取用户计算机上所有可用PostgreSQL
数据库的列表?
在postgreSQL中有两种方法:
'l
SELECT datname FROM pg_database;
使用Npgsql
您可以使用这样的代码片段:
IEnumerable<string> GetDatabaseNames()
{
var connStrBuilder = new NpgsqlConnectionStringBuilder();
connStrBuilder.Host = "localhost";
connStrBuilder.Username = "theduck";
connStrBuilder.Password = "password123";
connStrBuilder.Database = "postgres"; // this database is always present
using (var conn = new NpgsqlConnection(connStrBuilder.ConnectionString))
{
conn.Open();
using (var command = new NpgsqlCommand("SELECT datname FROM pg_database WHERE datistemplate = false ORDER BY datname;", conn))
using (var reader = command.ExecuteReader())
{
while (reader.Read())
{
yield return reader.GetString(0);
}
}
}
}