SQL Server: 동적 SQL 쿼리 결과를 변수로 캡처
저장 프로시저에서는 동적 SQL을 활용하여 즉시 쿼리를 작성하는 경우가 많습니다. 핵심 과제는 프로시저 자체 내에서 이러한 동적 쿼리의 결과를 검색하는 것입니다.
다음 시나리오를 고려해보세요.
<code class="language-sql">DECLARE @sqlCommand nvarchar(1000) DECLARE @city varchar(75) SET @city = 'London' SET @sqlCommand = 'SELECT COUNT(*) FROM customers WHERE City = @city' EXECUTE sp_executesql @sqlCommand, N'@city nvarchar(75)', @city = @city</code>
이 코드 조각은 COUNT(*)
쿼리를 동적으로 생성하지만 결과를 캡처하지는 않습니다. 이 문제를 해결하려면 수정된 접근 방식이 필요합니다.
<code class="language-sql">DECLARE @sqlCommand NVARCHAR(1000) DECLARE @count INT DECLARE @city VARCHAR(75) SET @city = 'New York' SET @sqlCommand = 'SELECT @cnt=COUNT(*) FROM customers WHERE City = @city' EXECUTE sp_executesql @sqlCommand, N'@city nvarchar(75), @cnt int OUTPUT', @city = @city, @cnt = @count OUTPUT SELECT @count</code>
자세한 설명은 다음과 같습니다.
결과 변수 선언: 쿼리의 출력을 보관하기 위해 @cnt
을 INT
으로 선언합니다.
동적 SQL 수정: SELECT
문은 COUNT(*)
결과를 @cnt
: SELECT @cnt=COUNT(*)
에 할당하도록 조정됩니다.
OUTPUT과 함께 sp_executesql
사용: sp_executesql
은 OUTPUT
매개변수와 함께 사용되어 @cnt
이 쿼리에서 값을 받도록 지정합니다. 매개변수 선언 @cnt int OUTPUT
에 유의하세요.
결과 검색: 실행 후 @cnt
에 개수가 포함됩니다. SELECT @count
저장된 값을 표시합니다.
이 세련된 방법은 동적 SQL 결과를 변수로 효율적으로 캡처하여 저장 프로시저 내에서 추가 처리 또는 반환을 가능하게 합니다.
위 내용은 동적 SQL 쿼리 결과를 SQL Server의 변수로 캡처하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!