다음을 통해 공유


Transact-SQL의 OLE 자동화 개체

Transact-SQL에는 Transact-SQL 일괄 처리, 저장 프로시저 및 트리거를 통해 OLE 자동화 개체를 참조할 수 있도록 하는 몇 가지 시스템 저장 프로시저가 포함됩니다. 이러한 시스템 저장 프로시저는 확장 저장 프로시저처럼 실행되며 저장 프로시저를 통해 실행되는 OLE 자동화 개체는 확장 저장 프로시저와 같은 방식으로 SQL Server 데이터베이스 엔진 인스턴스의 주소 공간에서 실행됩니다.

OLE 자동화 저장 프로시저를 사용하여 Transact-SQL 일괄 처리에서 IDispatch 인터페이스를 제공하는 개체와 같은 사용자 지정 OLE 자동화 개체와 SQL-DMO 개체를 참조할 수 있습니다. Microsoft Visual Basic에서 생성된 사용자 지정 종속 프로세스 OLE 서버에는 Class_InitializeClass_Terminate 서브루틴에 대한 오류 처리기(On Error GoTo 문으로 지정)가 있어야 합니다. Class_InitializeClass_Terminate 서브루틴의 오류가 처리되지 않을 경우 데이터베이스 엔진 인스턴스의 액세스 위반과 같은 예상치 못한 오류가 발생할 수 있습니다. 또한 다른 서브루틴에 대한 오류 처리기도 권장됩니다.

Transact-SQL의 OLE 자동화 개체를 사용하려면 우선 sp_OACreate 시스템 저장 프로시저를 호출하여 데이터베이스 엔진 인스턴스의 주소 공간에 개체의 인스턴스를 만들어야 합니다.

개체의 인스턴스가 생성된 후에는 다음과 같은 저장 프로시저를 호출하여 개체의 속성, 메서드 및 개체 관련 오류 정보에 대한 작업을 수행합니다.

  • 속성 값을 가져오는 sp_OAGetProperty

  • 속성 값을 설정하는 sp_OASetProperty

  • 메서드를 호출하는 sp_OAMethod

  • 최신 오류 정보를 가져오는 sp_OAGetErrorInfo

개체가 더 이상 필요하지 않을 때는 sp_OADestroy를 호출하여 sp_OACreate로 생성된 개체의 인스턴스를 할당 취소합니다.

OLE 자동화 개체는 속성 값과 메서드를 통해 데이터를 반환합니다. sp_OAGetPropertysp_OAMethod는 결과 집합의 형식으로 이러한 데이터 값을 반환합니다.

OLE 자동화 개체의 범위는 일괄 처리입니다. 개체의 모든 참조는 하나의 일괄 처리, 저장 프로시저 또는 트리거 안에 들어 있어야 합니다.

개체를 참조할 때 SQL Server OLE 자동화 개체는 참조되는 개체 안에 포함된 다른 개체들 간의 순회 검색을 지원합니다. 예를 들어 SQL-DMO SQLServer 개체를 사용할 때 해당 서버에 포함된 데이터베이스와 테이블에 대한 참조를 만들 수 있습니다.