커서 없이 레코드 대량 삽입 및 ID 값 검색
테이블에 여러 레코드를 삽입하는 것은 데이터베이스 프로그래밍에서 일반적인 작업입니다. 특히 한 테이블에서 다른 테이블로 데이터를 복사할 때 새 레코드에 대해 생성된 ID 값을 얻는 것이 바람직합니다. 이와 관련하여 Microsoft SQL Server 2005는 OUTPUT 절을 사용하여 효율적인 솔루션을 제공합니다.
테이블 B에서 테이블 A로 데이터가 삽입되는 제공된 코드 조각을 고려하면:
Create Table A (id int identity, Fname nvarchar(50), Lname nvarchar(50)) Create Table B (Fname nvarchar(50), Lname nvarchar(50), NewId int) Insert into A(fname, lname) SELECT fname, lname FROM B
To 테이블 A에 새로 삽입된 레코드의 ID 값을 검색하려면 다음 기술을 사용할 수 있습니다.
OUTPUT 절
OUTPUT 절을 사용하면 삽입, 업데이트 또는 삭제 작업 중에 생성된 값을 검색할 수 있습니다. 이 경우 이를 사용하여 삽입된 행의 ID 값을 캡처할 수 있습니다.
DECLARE @output TABLE (id int) Insert into A (fname, lname) OUTPUT inserted.ID INTO @output SELECT fname, lname FROM B
테이블 변수(@output)를 생성하고 OUTPUT insert.ID 표현식을 지정하여 쿼리에 다음을 지시합니다. 삽입된 레코드의 ID 값을 @output으로 반환합니다.
테이블 쿼리 변수
삽입 작업이 완료되면 @output 테이블 변수를 쿼리하여 ID 값을 얻을 수 있습니다.
select * from @output
이렇게 하면 하나의 열(id)이 있는 테이블이 표시됩니다. ) 새로 삽입된 레코드의 ID 값을 포함합니다. 원하는 경우 이 값을 사용하여 테이블 B의 해당 레코드를 업데이트할 수 있습니다.
위 내용은 커서 없이 SQL Server에 레코드를 대량 삽입한 후 ID 값을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!