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 값에 액세스하거나 @@IDENTITY
및 SCOPE_IDENTITY()
이 적합하지 않은 경우에 유용합니다.
OUTPUT 절: 명령문 수준 신원 검색
OUTPUT
문의 INSERT
절은 문의 범위 내에 삽입된 행의 ID에 액세스하는 직접적인 방법을 제공합니다. @@IDENTITY
과 달리 범위 간 문제를 방지합니다. 그러나 출력을 저장하려면 테이블 변수나 임시 테이블을 사용해야 하므로 잠재적으로 복잡성이 증가하고 성능에 영향을 미칠 수 있습니다. 비판적으로 이는 병렬 실행에서 ID를 검색하는 유일한 보장된 방법입니다.
올바른 신원 검색 방법을 선택하는 것은 특정 애플리케이션 요구 사항에 따라 다릅니다. SCOPE_IDENTITY()
은 일반적으로 권장되지만 @@IDENTITY
, IDENT_CURRENT()
및 OUTPUT
절은 특정 상황에서 귀중한 대안을 제공합니다.
위 내용은 올바른 SQL Server ID 검색 기능(@@IDENTITY, SCOPE_IDENTITY(), IDENT_CURRENT() 또는 OUTPUT)을 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!