다음을 통해 공유


SQL Server PowerShell 공급자

Windows PowerShell용 SQL Server 공급자는 파일 시스템 경로와 유사한 경로에 SQL Server 개체의 계층 구조를 노출합니다. 경로를 사용하여 개체를 찾은 다음 SMO(SQL Server Management Object) 모델의 메서드를 사용하여 개체에 대한 작업을 수행할 수 있습니다.

SQL Server PowerShell 공급자의 이점

SQL Server 공급자가 구현한 경로를 사용하면 SQL Server 인스턴스의 모든 개체를 쉽고 대화형으로 검토할 수 있습니다. 일반적으로 파일 시스템 경로를 탐색하는 데 사용하는 명령과 유사한 Windows PowerShell 별칭을 사용하여 경로를 탐색할 수 있습니다.

SQL Server PowerShell 계층 구조

계층 구조에서 데이터 또는 개체 모델을 나타낼 수 있는 제품은 Windows PowerShell 공급자를 사용하여 계층 구조를 노출합니다. 계층 구조는 Windows 파일 시스템에서 사용하는 것과 유사한 드라이브 및 경로 구조를 사용하여 노출됩니다.

각 Windows PowerShell 공급자는 하나 이상의 드라이브를 구현합니다. 각 드라이브는 관련 개체 계층 구조의 루트 노드입니다. SQL Server 공급자는 SQLSERVER: 드라이브를 구현합니다. 또한 공급자는 SQLSERVER: 드라이브에 대한 기본 폴더 집합을 정의합니다. 각 폴더와 해당 하위 폴더는 SQL Server 관리 개체 모델을 사용하여 액세스할 수 있는 개체 집합을 나타냅니다. 이러한 기본 폴더 중 하나로 시작하는 경로의 하위 폴더에 초점을 맞춘 경우 연결된 개체 모델의 메서드를 사용하여 노드가 나타내는 개체에 대한 작업을 수행할 수 있습니다. SQL Server 2014 공급자가 구현한 Windows PowerShell 폴더는 다음 표에 나와 있습니다.

폴더 SQL Server 개체 모델 네임스페이스 개체
SQLSERVER:\SQL Microsoft.SqlServer.Management.Smo

Microsoft.SqlServer.Management.Smo.Agent

Microsoft.SqlServer.Management.Smo.Broker

Microsoft.SqlServer.Management.Smo.Mail
테이블, 뷰 및 저장 프로시저와 같은 데이터베이스 개체입니다.
SQLSERVER:\SQLPolicy Microsoft.SqlServer.Management.Dmf

Microsoft.SqlServer.Management.Facets
정책 및 패싯 등의 정책 기반 관리 객체.
SQLSERVER:\SQLRegistration Microsoft.SqlServer.Management.RegisteredServers

Microsoft.SqlServer.Management.Smo.RegSvrEnum
서버 그룹 및 등록된 서버와 같은 등록된 서버 개체입니다.
SQLSERVER:\Utility Microsoft.SqlServer.Management.Utility 데이터베이스 엔진의 관리되는 인스턴스와 같은 유틸리티 개체입니다.
SQLSERVER:\DAC Microsoft.SqlServer.Management.DAC DAC 패키지와 같은 데이터 계층 애플리케이션 개체 및 DAC 배포와 같은 작업
SQLSERVER:\DataCollection Microsoft.SqlServer.Management.Collector 컬렉션 집합 및 구성 저장소와 같은 데이터 수집기 개체입니다.
SQLSERVER:\IntegrationServices Microsoft.SqlServer.Management.IntegrationServices 프로젝트, 패키지 및 환경과 같은 Integration Services 개체입니다.
SQLSERVER:\SQLAS Microsoft.AnalysisServices 큐브, 집계 및 차원과 같은 Analysis Services 개체입니다.

예를 들어 SQLSERVER:\SQL 폴더를 사용하여 SMO 개체 모델에서 지원하는 모든 개체를 나타낼 수 있는 경로를 시작할 수 있습니다. SQLSERVER:\SQL 경로의 선행 부분은 SQLSERVER:\SQL\ComputerName\InstanceName입니다. 인스턴스 이름 뒤의 노드는 개체 컬렉션(예: 데이터베이스 또는 )과 개체 이름(예: AdventureWorks2012)을 대체합니다. 스키마는 개체 클래스로 표시되지 않습니다. 테이블 또는 뷰와 같은 스키마에서 최상위 개체의 노드를 지정할 때 는 SchemaName.ObjectName 형식으로 개체 이름을 지정해야 합니다.

로컬 컴퓨터의 데이터베이스 엔진 기본 인스턴스에 있는 AdventureWorks2012 데이터베이스의 구매 스키마에 있는 공급업체 테이블의 경로입니다.

SQLSERVER:\SQL\localhost\DEFAULT\Databases\AdventureWorks2012\Tables\Purchasing.Vendor  

SMO 개체 모델 계층 구조에 대한 자세한 내용은 SMO 개체 모델 다이어그램을 참조하세요.

경로의 컬렉션 노드는 연결된 개체 모델의 컬렉션 클래스와 연결됩니다. 개체 이름 노드는 다음 표와 같이 연결된 개체 모델의 개체 클래스와 연결됩니다.

경로 SMO 클래스
SQLSERVER:\SQL\MyComputer\DEFAULT\Databases DatabaseCollection
SQLSERVER:\SQL\MyComputer\DEFAULT\Databases\AdventureWorks2012 Database

SQL Server 공급자 작업

작업 설명 주제
Windows PowerShell cmdlet을 사용하여 경로의 노드를 탐색하고 각 노드에서 해당 노드의 개체 목록을 가져오는 방법을 설명합니다. SQL Server PowerShell 경로 탐색
SMO 메서드 및 속성을 사용하여 경로의 노드가 나타내는 개체에 대해 보고하고 작업을 수행하는 방법을 설명합니다. 또한 해당 노드에 대한 SMO 메서드 및 속성 목록을 가져오는 방법을 설명합니다. SQL Server PowerShell 경로 작업
SMO URN(Uniform Resource Name)을 SQL Server 공급자 경로로 변환하는 방법을 설명합니다. URL을 SQL Server 공급자 경로로 변환
SQL Server 공급자를 사용하여 SQL Server 인증 연결을 여는 방법을 설명합니다. 기본적으로 공급자는 Windows PowerShell 세션을 실행하는 Windows 계정의 자격 증명을 사용하여 만든 Windows 인증 연결을 사용합니다. 데이터베이스 엔진 PowerShell에서 인증 관리

또한 참조하십시오

SQL Server PowerShell