SQL Server 2008 이상에서 테이블 변수를 동적 SQL에 통합
SQL Server 2008 이상 버전에서 동적 SQL 쿼리를 작성하려면 테이블 변수를 통합해야 하는 경우가 많습니다. 그러나 직접 포함하면 "선언되지 않은 테이블 변수" 오류가 발생하는 경우가 많습니다.
해결책은 테이블 반환 매개변수를 활용하는 것입니다. 이러한 매개변수를 사용하면 기본 테이블을 수정하지 않고도 테이블 변수를 동적 SQL로 전달할 수 있습니다.
일반적인 문제를 살펴보겠습니다.
<code class="language-sql">set @col_name = 'Assoc_Item_' + Convert(nvarchar(2), @curr_row1); set @sqlstat = 'update @RelPro set ' + @col_name + ' = (Select relsku From @TSku Where tid = ' + Convert(nvarchar(2), @curr_row1) + ') Where RowID = ' + Convert(nvarchar(2), @curr_row); Exec(@sqlstat);</code>
@RelPro
및 @TSku
이 동적 SQL 컨텍스트 내에서 인식되지 않기 때문에 이 코드는 실패합니다. @TSku
을 올바르게 전달하려면 테이블 반환 매개변수를 활용하세요.
<code class="language-sql">EXEC sp_executesql N'SELECT * FROM @T', N'@T MyTable READONLY', @T=@TSku;</code>
여기서 @TSku
는 읽기 전용 매개변수(READONLY
)로 sp_executesql
에 전달됩니다. @T
매개변수는 동적 SQL 문 내에서 자리 표시자 역할을 합니다. 이 방법은 테이블 변수를 동적 쿼리에 깔끔하게 통합하여 선언 오류를 방지하고 원활한 실행을 보장합니다. 이 접근 방식은 테이블 변수와 관련된 동적 SQL 쿼리를 관리하는 강력하고 효율적인 방법을 제공합니다.
위 내용은 SQL Server 2008에서 SQL 문에 테이블 변수를 동적으로 삽입하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!