>데이터 베이스 >MySQL 튜토리얼 >SQL Server의 OPENQUERY에 매개변수를 전달하려면 어떻게 해야 합니까?

SQL Server의 OPENQUERY에 매개변수를 전달하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-14 12:27:42399검색

How Can I Pass Parameters to an OPENQUERY in SQL Server?

SQL Server의 OPENQUERY에 매개변수 전달

SQL Server의 OPENQUERY 문은 연결된 서버에서 쿼리를 실행합니다. 그러나 OPENQUERY 문 내에 매개변수를 직접 포함하는 것은 지원되지 않습니다. Microsoft 문서에는 OPENQUERY 변수를 인수로 허용하지 않는다고 명시되어 있습니다. 효과적인 해결 방법을 살펴보겠습니다.

방법 1: 값 하드코딩(제한된 수의 매개변수에 대해)

이 접근 방식은 몇 가지 특정 값만 전달해야 하는 경우에 적합합니다. 문자열 연결은 쿼리를 작성하는 데 사용됩니다.

<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>

방법 2: 동적 쿼리 구성(보다 복잡한 쿼리 또는 동적 연결된 서버 이름의 경우)

연결된 서버 이름이 가변적인 더 복잡한 쿼리나 시나리오의 경우 동적 SQL이 솔루션을 제공합니다.

<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>

방법 3: sp_executesql 사용(인용 문제 최소화)

복잡한 문자열 연결 및 잠재적인 인용 문제를 방지하기 위해 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>

이러한 방법은 OPENQUERY 문에 매개 변수를 통합하여 연결된 서버와 효율적으로 상호 작용할 수 있는 실용적인 방법을 제공합니다. 특정 요구사항과 복잡성에 가장 적합한 방법을 선택하세요.

위 내용은 SQL Server의 OPENQUERY에 매개변수를 전달하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.