> 데이터 베이스 > MySQL 튜토리얼 > 저장된 프로 시저를 구조를 정의하지 않고 임시 테이블에 삽입하는 방법은 무엇입니까?

저장된 프로 시저를 구조를 정의하지 않고 임시 테이블에 삽입하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2025-01-25 02:32:13
원래의
361명이 탐색했습니다.

How to Insert Stored Procedure Results into a Temporary Table Without Defining its Structure?

구조를 미리 정의하지 않고 임시 테이블에 저장 프로시저 결과 삽입

문제: 테이블 스키마를 미리 명시적으로 정의하지 않고 저장 프로시저의 결과로 임시 테이블을 어떻게 채울 수 있나요?

해결책: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿