ORDER BY 없이 SQL Server 2005에서 자동 증가 ID 생성
자동 증가하는 동안 한 테이블의 데이터를 다른 테이블에 삽입해야 하는 필요성 비식별 열은 문제가 될 수 있습니다. 표준 접근 방식에는 커서를 사용하거나 테이블 변수를 생성하는 것이 포함되지만 이는 비효율적일 수 있습니다.
적법한 ORDER BY 필드가 없는 경우 ROW_NUMBER 함수를 사용할 수 있습니다. 그러나 명시적인 순서가 없다고 해서 원래 데이터 순서의 보존이 보장되는 것은 아닙니다. 이는 "주문되지 않음"이 "원래 순서 유지"와 다르기 때문입니다.
이 문제를 해결하려면 다음과 같이 명시적인 순서 지정을 피하는 것이 해결 방법입니다.
INSERT dbo.TargetTable (ID, FIELD) SELECT Row_Number() OVER (ORDER BY (SELECT 1)) Coalesce( (SELECT Max(ID) FROM dbo.TargetTable WITH (TABLOCKX, HOLDLOCK)), 0 ), FieldValue FROM dbo.SourceTable WHERE {somecondition};
이 접근 방식은 Max ID를 계산하고 동시성 오류를 방지하기 위해 잠금을 획득하는 동안 데이터를 삽입합니다.
그러나 ID 열을 사용하면 필요가 없으므로 ID 열을 사용하는 것이 좋습니다. 잠금을 위해 최적의 동시성을 보장합니다. ID 열은 SQL Server의 ID 자동 증가를 위한 보다 효율적이고 강력한 솔루션을 제공합니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3