如何获取SQL Server实例上的可用数据库列表?我计划在VB.NET的组合框中列出他们的列表。


当前回答

排除系统数据库:

SELECT name FROM master.dbo.sysdatabases where sid <>0x01

其他回答

使用下面的查询来获取所有的数据库:

select * from sys.databases

如果您只需要用户定义的数据库;

select * from sys.databases WHERE name NOT IN ('master', 'tempdb', 'model', 'msdb'); 

一些系统数据库名称是(resource,distribution,reportservice,reportservicetempdb),如果您的机器中默认有上述数据库,只需将其插入到查询中。

在SQL Server 7中,dbid 1 ~ dbid 4为系统dbs。

执行:

从master.sys.databases中选择名称

这是目前首选的方法,而不是dbo。Sysdatabases,它已经被弃用一段时间了。


执行这个查询:

SELECT name FROM master.dbo.sysdatabases

或者如果你愿意

EXEC sp_databases

我使用下面的SQL Server Management Objects代码来获得一个数据库列表,这些数据库既不是系统数据库,也不是快照。

using Microsoft.SqlServer.Management.Smo;

public static string[] GetDatabaseNames( string serverName )
{
   var server = new Server( serverName );
   return ( from Database database in server.Databases 
            where !database.IsSystemObject && !database.IsDatabaseSnapshot
            select database.Name 
          ).ToArray();
}
SELECT [name] 
FROM master.dbo.sysdatabases 
WHERE dbid > 4 

工作在我们的SQL Server 2008