Programing

SQL Server에서 데이터베이스 목록 가져 오기

lottogame 2020. 3. 3. 22:54
반응형

SQL Server에서 데이터베이스 목록 가져 오기


SQL Server 인스턴스에서 사용 가능한 데이터베이스 목록을 얻으려면 어떻게해야합니까? VB.NET의 콤보 상자에 목록을 만들 계획입니다.


실행 :

SELECT name FROM master.sys.databases

이 방법 dbo.sysdatabases은 한동안 사용되지 않고 현재 선호되는 접근 방식 입니다.


이 쿼리를 실행하십시오.

SELECT name FROM master.dbo.sysdatabases

또는 원하는 경우

EXEC sp_databases

비 사용자 데이터베이스의 수에 대한 모호성을 고려하여 다음을 추가해야합니다.

WHERE name NOT IN ('master', 'tempdb', 'model', 'msdb');

보고 서비스 데이터베이스의 이름을 추가하십시오.


시스템 데이터베이스를 제외하려면 다음을 수행하십시오.

SELECT [name]
FROM master.dbo.sysdatabases
WHERE dbid > 6

편집 : 오후 2시 36 분 2/5/2013

정확한 database_id로 업데이트되었습니다. 데이터베이스 ID가 1에서 4 사이 인 시스템 데이터베이스 목록을 건너 뛰려면 4보다 커야합니다.

SELECT * 
FROM sys.databases d
WHERE d.database_id > 4

SELECT [name] 
FROM master.dbo.sysdatabases 
WHERE dbid > 4 

SQL Server 2008에서 작동


.NET을 사용하므로 SQL Server 관리 개체를 사용할 수 있습니다.

Dim server As New Microsoft.SqlServer.Management.Smo.Server("localhost")
For Each db As Database In server.Databases
    Console.WriteLine(db.Name)
Next

혼동하지 마십시오. 아래의 간단한 쿼리를 사용하여 모든 데이터베이스를 얻으십시오.

select * from sys.databases

사용자 정의 데이터베이스 만 필요한 경우

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

시스템 데이터베이스 이름 중 일부 (자원, 배포, 보고서 서비스, 보고서 서비스 온도)는 쿼리에 삽입하기 만합니다. 당신이 당신의 컴퓨터에 위의 db를 기본값으로 가지고 있다면.


SELECT [name] 
FROM master.dbo.sysdatabases 
WHERE dbid > 4 and [name] <> 'ReportServer' and [name] <> 'ReportServerTempDB'

보고 사용 여부에 관계없이 두 가지 조건 모두에서 작동합니다.


다음 SQL Server 관리 개체 코드를 사용하여 시스템 데이터베이스가 아니며 스냅 샷이 아닌 데이터베이스 목록을 가져옵니다.

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();
}

시스템 데이터베이스 및 ReportServer 테이블을 생략하려면 (설치된 경우) :

select
            DATABASE_NAME   = db_name(s_mf.database_id)
             from
           sys.master_files s_mf
        where
            s_mf.state = 0 and -- ONLINE
            has_dbaccess(db_name(s_mf.database_id)) = 1
            and db_name(s_mf.database_id) NOT IN ('master', 'tempdb', 'model', 'msdb')
             and db_name(s_mf.database_id) not like 'ReportServer%'
        group by s_mf.database_id
        order by 1

이것은 Sql Server 2008/2012/2014에서 작동합니다. 대부분의 쿼리는 " sp_databases "시스템 저장 프로 시저 에서옵니다 . 불필요한 열만 제거하고 위치를 추가했습니다.


SQL Server 7에서 dbid 1 ~ 4는 시스템 db입니다.


보고서 서버 데이터베이스를 실행 중이 아니기 때문에 이것이 보고서 서버 데이터베이스를 생략하는지 확실하지 않지만 본 SQL 시스템에서 사용자가 소유 한 데이터베이스를 생략 할 수 있습니다.

    SELECT  db.[name] as dbname 
    FROM [master].[sys].[databases] db
    LEFT OUTER JOIN  [master].[sys].[sysusers] su on su.sid = db.owner_sid
    WHERE su.sid is null
    order by db.[name]

아마도 나는 도도 야!

show databases; 나를 위해 일했다.


SQL Server 2008 R2에서는 다음과 같이 작동합니다.

select name 
from master.sys.databases 
where owner_sid > 1;

그리고 사용자가 만든 데이터베이스 만 나열하십시오.


다음을 사용하여 모든 데이터베이스 이름을 찾을 수 있습니다.

 select name from sys.sysdatabases

시스템 데이터베이스를 제외하려면 다음을 수행하십시오.

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

참고 URL : https://stackoverflow.com/questions/147659/get-list-of-databases-from-sql-server



반응형