>데이터 베이스 >MySQL 튜토리얼 >커서 없이 SQL Server에 레코드를 대량 삽입한 후 ID 값을 검색하는 방법은 무엇입니까?

커서 없이 SQL Server에 레코드를 대량 삽입한 후 ID 값을 검색하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-03 17:11:40687검색

How to Retrieve Identity Values After Bulk Inserting Records in SQL Server without Cursors?

커서 없이 레코드 대량 삽입 및 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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