> 데이터 베이스 > MySQL 튜토리얼 > 올바른 SQL Server ID 검색 기능(@@IDENTITY, SCOPE_IDENTITY(), IDENT_CURRENT() 또는 OUTPUT)을 선택하는 방법은 무엇입니까?

올바른 SQL Server ID 검색 기능(@@IDENTITY, SCOPE_IDENTITY(), IDENT_CURRENT() 또는 OUTPUT)을 선택하는 방법은 무엇입니까?

DDD
풀어 주다: 2025-01-23 09:07:09
원래의
506명이 탐색했습니다.

How to Choose the Right SQL Server Identity Retrieval Function: @@IDENTITY, SCOPE_IDENTITY(), IDENT_CURRENT(), or OUTPUT?

SQL Server ID 관리: 올바른 함수 선택(@@IDENTITY, SCOPE_IDENTITY(), IDENT_CURRENT(), OUTPUT)

많은 데이터베이스 애플리케이션에서는 특히 ID 열이 포함된 테이블을 처리할 때 새로 삽입된 행의 ID에 액세스해야 합니다. SQL Server는 이를 달성하기 위한 여러 가지 방법을 제공합니다. 각 방법에는 특정한 용도와 잠재적인 단점이 있습니다.

@@IDENTITY: 세션 전체 ID 검색

@@IDENTITY은 테이블이나 범위에 관계없이 현재 세션에서 생성된 마지막 ID 값을 검색합니다. 주의 사항: @@IDENTITY은 다른 범위(예: 트리거)에서 값을 반환할 수 있으므로 잠재적으로 부정확한 결과가 발생할 수 있습니다.

SCOPE_IDENTITY(): 범위별 ID 검색

SCOPE_IDENTITY()은 현재 세션 및 범위(일반적으로 현재 데이터베이스) 내에서 생성된 마지막 ID 값을 반환하는 보다 정확한 접근 방식을 제공합니다. 안정성으로 인해 대부분의 시나리오에서 선호되는 방법입니다. (n) 구문

을 사용하여 범위를 더욱 구체화할 수 있습니다.

IDENT_CURRENT(): 테이블별 ID 검색

IDENT_CURRENT('tableName')은 세션이나 범위에 관계없이 지정된 테이블에 대해 생성된 마지막 ID 값을 검색합니다. 이는 현재 세션에서 수정되지 않은 테이블의 ID 값에 액세스하거나 @@IDENTITYSCOPE_IDENTITY()이 적합하지 않은 경우에 유용합니다.

OUTPUT 절: 명령문 수준 신원 검색

OUTPUT 문의 INSERT 절은 문의 범위 내에 삽입된 행의 ID에 액세스하는 직접적인 방법을 제공합니다. @@IDENTITY과 달리 범위 간 문제를 방지합니다. 그러나 출력을 저장하려면 테이블 변수나 임시 테이블을 사용해야 하므로 잠재적으로 복잡성이 증가하고 성능에 영향을 미칠 수 있습니다. 비판적으로 이는 병렬 실행에서 ID를 검색하는 유일한 보장된 방법입니다.

올바른 신원 검색 방법을 선택하는 것은 특정 애플리케이션 요구 사항에 따라 다릅니다. SCOPE_IDENTITY()은 일반적으로 권장되지만 @@IDENTITY, IDENT_CURRENT()OUTPUT 절은 특정 상황에서 귀중한 대안을 제공합니다.

위 내용은 올바른 SQL Server ID 검색 기능(@@IDENTITY, SCOPE_IDENTITY(), IDENT_CURRENT() 또는 OUTPUT)을 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿