>데이터 베이스 >MySQL 튜토리얼 >커서를 사용하여 T-SQL 쿼리 결과를 반복하는 방법은 무엇입니까?

커서를 사용하여 T-SQL 쿼리 결과를 반복하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-30 14:47:14996검색

How to Iterate Through T-SQL Query Results Using Cursors?

T-SQL에서 쿼리 결과 반복

쿼리 SELECT @id=table.id FROM 테이블의 결과를 반복하려면, T-SQL에서 CURSOR를 활용할 수 있습니다. 다음은 이를 달성하는 방법을 보여주는 코드 조각입니다.

DECLARE @id INT;
DECLARE @name NVARCHAR(100);
DECLARE @getid CURSOR;

SET @getid = CURSOR FOR
SELECT
    table.id,
    table.name
FROM
    table;

OPEN @getid;
FETCH NEXT
FROM @getid
INTO @id, @name;
WHILE @@FETCH_STATUS = 0
BEGIN
    EXEC stored_proc @varName = @id, @otherVarName = 'test', @varForName = @name;
    FETCH NEXT
    FROM @getid
    INTO @id, @name;
END;

CLOSE @getid;
DEALLOCATE @getid;

이 스크립트에서:

  • @getid라는 CURSOR가 쿼리 결과를 반복하기 위해 생성됩니다.
  • OPEN 문은 쿼리를 실행하고 결과를 커서.
  • FETCH NEXT 문은 결과의 첫 번째 행을 검색하고 @id 및 @name 변수에 값을 할당합니다.
  • WHILE 루프는 결과가 없을 때까지 커서에서 행을 계속 가져옵니다. 처리할 행이 더 많습니다.
  • 각 행에 대해 EXEC 문은 @varName, @otherVarName 및 매개변수를 사용하여 저장 프로시저 Stored_proc를 실행합니다. @varForName은 테이블의 해당 값으로 설정됩니다.
  • 모든 행이 처리된 후 CLOSE 및 DEALLOCATE 문이 닫히고 메모리에서 커서가 제거됩니다.

위 내용은 커서를 사용하여 T-SQL 쿼리 결과를 반복하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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