문제: 테이블 스키마를 미리 명시적으로 정의하지 않고 저장 프로시저의 결과로 임시 테이블을 어떻게 채울 수 있나요?
해결책: OPENROWSET
기능을 활용하세요. 이 함수는 원격 쿼리를 실행하고 결과를 임시 테이블에 직접 삽입하여 쿼리 출력에서 테이블 구조를 동적으로 추론합니다.
예:
<code class="language-sql">-- Sample Stored Procedure CREATE PROC getBusinessLineHistory AS BEGIN SELECT * FROM sys.databases END GO -- Enable Ad Hoc Distributed Queries (required for OPENROWSET) sp_configure 'Show Advanced Options', 1 GO RECONFIGURE GO sp_configure 'Ad Hoc Distributed Queries', 1 GO RECONFIGURE GO -- Insert results into temporary table using OPENROWSET SELECT * INTO #MyTempTable FROM OPENROWSET('SQLNCLI', 'Server=(local)\SQL2008;Trusted_Connection=yes;', 'EXEC getBusinessLineHistory') -- Verify the data SELECT * FROM #MyTempTable</code>
이 코드는 먼저 샘플 저장 프로시저(getBusinessLineHistory
)를 정의합니다. 결정적으로 sp_configure
를 사용하여 "임시 분산 쿼리"를 활성화합니다. OPENROWSET
을 사용하기 위한 전제조건입니다.
OPENROWSET
은 원격으로 저장 프로시저를 실행하고, 반환된 데이터가 자동으로 #MyTempTable
에 삽입됩니다. 임시 테이블의 구조는 저장 프로시저에서 반환된 데이터 유형을 기반으로 동적으로 생성됩니다. 마지막으로 SELECT
문은 데이터가 성공적으로 삽입되었음을 확인합니다. 이 접근 방식을 사용하면 임시 테이블의 스키마를 수동으로 정의할 필요가 없습니다.
위 내용은 저장된 프로 시저를 구조를 정의하지 않고 임시 테이블에 삽입하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!