Transact-SQL의 OLE 자동화 개체
Transact-SQL 에는 Transact-SQL 일괄 처리, 저장 프로시저 및 트리거를 통해 OLE 자동화 개체를 참조할 수 있도록 하는 몇 가지 시스템 저장 프로시저가 포함됩니다. 이러한 시스템 저장 프로시저는 확장 저장 프로시저처럼 실행되며 저장 프로시저를 통해 실행되는 OLE 자동화 개체는 확장 저장 프로시저와 같은 방식으로 SQL Server 데이터베이스 엔진 인스턴스의 주소 공간에서 실행됩니다.
OLE Automation 저장 프로시저를 사용하여 Transact-SQL 일괄 처리에서 IDispatch 인터페이스를 제공하는 개체와 같은 사용자 지정 OLE Automation 개체와 SQL-DMO 개체를 참조할 수 있습니다. Microsoft Visual Basic를 사용하여 만들어진 사용자 지정 종속 프로세스 OLE 서버에는 Class_Initialize 및 Class_Terminate 서브루틴에 대한 오류 처리기(On Error GoTo 문으로 지정)가 있어야 합니다. Class_Initialize 및 Class_Terminate 서브루틴의 오류가 처리되지 않을 경우 데이터베이스 엔진인스턴스의 액세스 위반과 같은 예상치 못한 오류가 발생할 수 있습니다. 또한 다른 서브루틴에 대한 오류 처리기도 권장됩니다.
Transact-SQL에서 OLE Automation 개체를 사용하는 첫 번째 단계는 sp_OACreate 시스템 저장 프로시저를 호출하여 데이터베이스 엔진 instance 주소 공간에 개체의 instance 만드는 것입니다.
개체의 인스턴스가 생성된 후에는 다음과 같은 저장 프로시저를 호출하여 개체의 속성, 메서드 및 개체 관련 오류 정보에 대한 작업을 수행합니다.
속성 값을 가져오는sp_OAGetProperty
속성 값을 설정하는sp_OASetProperty
메서드를 호출하는sp_OAMethod
최신 오류 정보를 가져오는sp_OAGetErrorInfo
개체가 더 이상 필요하지 않을 때는 sp_OADestroy 를 호출하여 sp_OACreate로 생성된 개체의 인스턴스를 할당 취소합니다.
OLE 자동화 개체는 속성 값과 메서드를 통해 데이터를 반환합니다. sp_OAGetProperty 및 sp_OAMethod 는 결과 집합의 형식으로 이러한 데이터 값을 반환합니다.
OLE Automation 개체의 범위는 일괄 처리입니다. 개체의 모든 참조는 하나의 일괄 처리, 저장 프로시저 또는 트리거 안에 들어 있어야 합니다.
개체를 참조할 때 SQL Server OLE 자동화 개체는 참조되는 개체 안에 포함된 다른 개체들 간의 순회 검색을 지원합니다. 예를 들어 SQL-DMO SQLServer 개체를 사용할 때 해당 서버에 포함된 데이터베이스와 테이블에 대한 참조를 만들 수 있습니다.
관련 내용
Ole Automation Procedures 서버 구성 옵션
sp_OAGetProperty(Transact-SQL)
sp_OASetProperty(Transact-SQL)