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
'Programing' 카테고리의 다른 글
Python에서 현재 스크립트 이름 가져 오기 (0) | 2020.03.04 |
---|---|
사소한 키의 경우 unorder_map보다 map을 사용하면 어떤 이점이 있습니까? (0) | 2020.03.03 |
쉘에서 한 줄에 여러 명령 실행 (0) | 2020.03.03 |
자식 추적에서 폴더 제거 (0) | 2020.03.03 |
Git Extensions : Win32 오류 487 : Cygwin의 힙을위한 공간을 예약 할 수 없음, Win32 오류 0 (0) | 2020.03.03 |