데이터베이스 프로그래밍에서는 삽입 작업 후 기본 키 ID 필드의 값을 검색하는 것이 중요합니다. 이 문서에서는 이 목적을 위한 다양한 방법을 검토하고 다양한 시나리오에 대한 기능과 적합성에 대한 통찰력을 제공합니다.
@@IDENTITY는 관계없이 현재 세션에서 생성된 마지막 ID 값을 검색합니다.
declare @t table ( id int identity primary key, somecol datetime default getdate() ) insert into @t default values select @@IDENTITY --returns 1
@@IDENTITY의 단점은 범위에 국한되지 않는다는 것입니다. 따라서 현재 트랜잭션 외부의 문을 포함하여 세션의 모든 문에서 생성된 마지막 ID 값을 반환할 수 있습니다.
SCOPE_IDENTITY()는 세션 내에서 생성된 마지막 ID 값을 검색합니다. 현재 범위는 이를 생성한 문과 트랜잭션으로 제한됩니다.
select SCOPE_IDENTITY() --returns 1
SCOPE_IDENTITY() 반환된 ID 값이 현재 범위에 특정하도록 보장하므로 @@IDENTITY에 비해 더 정확한 방법입니다.
INSERT 문과 함께 OUTPUT 절을 사용하면 생성된 ID 값을 포함하여 삽입된 행을 포함하는 테이블.
Create Table #Testing ( id int identity, somedate datetime default getdate() ) insert into #Testing output inserted.* default values
OUTPUT은 단일 ID 내에서 한 번에 여러 ID 값을 검색하는 편리한 방법을 제공합니다. 거래. 그러나 이는 대상 테이블에만 적용되며 추가 테이블 생성 및 정리 작업이 필요합니다.
마지막 ID 값을 검색하는 방법 선택은 애플리케이션의 특정 요구 사항에 따라 다릅니다.
위 내용은 SQL Server에서 마지막 ID 값을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!