>데이터 베이스 >MySQL 튜토리얼 >SQL Server에서 마지막 ID 값을 검색하는 방법은 무엇입니까?

SQL Server에서 마지막 ID 값을 검색하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-29 17:48:14724검색

How to Retrieve the Last Identity Value in SQL Server?

마지막 ID 값을 검색하는 대체 방법: 종합 가이드

데이터베이스 프로그래밍에서는 삽입 작업 후 기본 키 ID 필드의 값을 검색하는 것이 중요합니다. 이 문서에서는 이 목적을 위한 다양한 방법을 검토하고 다양한 시나리오에 대한 기능과 적합성에 대한 통찰력을 제공합니다.

@@IDENTITY

@@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()

SCOPE_IDENTITY()는 세션 내에서 생성된 마지막 ID 값을 검색합니다. 현재 범위는 이를 생성한 문과 트랜잭션으로 제한됩니다.

select SCOPE_IDENTITY() --returns 1

SCOPE_IDENTITY() 반환된 ID 값이 현재 범위에 특정하도록 보장하므로 @@IDENTITY에 비해 더 정확한 방법입니다.

OUTPUT

INSERT 문과 함께 OUTPUT 절을 사용하면 생성된 ID 값을 포함하여 삽입된 행을 포함하는 테이블.

Create Table #Testing (  
    id int identity,  
    somedate datetime default getdate()  
)  
insert into #Testing  
output inserted.*  
default values

OUTPUT은 단일 ID 내에서 한 번에 여러 ID 값을 검색하는 편리한 방법을 제공합니다. 거래. 그러나 이는 대상 테이블에만 적용되며 추가 테이블 생성 및 정리 작업이 필요합니다.

결론

마지막 ID 값을 검색하는 방법 선택은 애플리케이션의 특정 요구 사항에 따라 다릅니다.

  • @@IDENTITY는 세션에 삽입된 행의 ID 값이 필요한 시나리오에 적합합니다. table.
  • SCOPE_IDENTITY()는 ID 값이 현재 범위에 특정해야 하며 트랜잭션의 정확성을 보장해야 하는 경우 바람직합니다.
  • OUTPUT을 사용하면 제어된 트랜잭션 내에서 여러 ID 값을 효율적으로 검색할 수 있습니다. .

위 내용은 SQL Server에서 마지막 ID 값을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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