> 데이터 베이스 > MySQL 튜토리얼 > SQL Server에서 OPENQUERY와 함께 매개 변수를 어떻게 사용할 수 있습니까?

SQL Server에서 OPENQUERY와 함께 매개 변수를 어떻게 사용할 수 있습니까?

Susan Sarandon
풀어 주다: 2025-01-14 12:41:44
원래의
999명이 탐색했습니다.

How Can I Use Parameters with OPENQUERY in SQL Server?

OPENQUERY에서 매개변수 사용

OPENQUERY는 연결된 서버 데이터에 액세스하기 위한 강력한 도구이지만 쿼리에 매개변수를 통합하는 것은 어려울 수 있습니다. 문서에는 OPENQUERY가 해당 매개변수에 대한 변수를 허용하지 않는다고 명시되어 있습니다.

해결책:

이러한 제한을 극복하기 위해 다음과 같은 몇 가지 해결 방법을 사용할 수 있습니다.

  • 기본 값 전달: 특정 값을 전달해야 하는 간단한 경우에는 다음과 같은 코드를 사용하세요.
<code class="language-sql">DECLARE @TSQL varchar(8000), @VAR char(2)
SELECT @VAR = 'CA'
SELECT @TSQL = 'SELECT * FROM OPENQUERY(MyLinkedServer,''SELECT * FROM pubs.dbo.authors WHERE state = ''''' + @VAR + ''''''')'
EXEC (@TSQL)</code>
로그인 후 복사
  • 전체 쿼리 전달: 전체 쿼리 또는 연결된 서버 이름을 전달해야 하는 경우 다음과 유사한 코드를 사용합니다.
<code class="language-sql">DECLARE @OPENQUERY nvarchar(4000), @TSQL nvarchar(4000), @LinkedServer nvarchar(4000)
SET @LinkedServer = 'MyLinkedServer'
SET @OPENQUERY = 'SELECT * FROM OPENQUERY('+ @LinkedServer + ','''
SET @TSQL = 'SELECT au_lname, au_id FROM pubs..authors'')'
EXEC (@OPENQUERY+@TSQL)</code>
로그인 후 복사
  • Sp_executesql 저장 프로시저 사용: 코드를 단순화하고 여러 겹의 따옴표를 피하려면 다음 방법을 사용하십시오.
<code class="language-sql">DECLARE @VAR char(2)
SELECT @VAR = 'CA'
EXEC MyLinkedServer.master.dbo.sp_executesql
N'SELECT * FROM pubs.dbo.authors WHERE state = @state',
N'@state char(2)',
@VAR</code>
로그인 후 복사

위 내용은 SQL Server에서 OPENQUERY와 함께 매개 변수를 어떻게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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