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