테이블 무결성 보호: SQL Server 저장 프로시저의 트랜잭션 기반 잠금
과제: 저장 프로시저가 실행되는 동안 테이블에 대한 동시 수정을 어떻게 방지합니까? 데이터 일관성을 유지하려면 프로시저 실행 중에 테이블을 잠가야 합니다.
초기 접근 방식(및 제한 사항): 저장 프로시저 내에서 LOCK TABLE
을 사용하는 것만으로는 충분하지 않습니다. 이 접근 방식은 필요한 독점 액세스를 제공하지 못하는 경우가 많습니다.
효과적인 솔루션: 핵심은 SQL Server 트랜잭션을 활용하는 것입니다.
<code class="language-sql">CREATE PROCEDURE ... AS BEGIN BEGIN TRANSACTION; -- Acquire exclusive lock on table 'a' for the duration of the transaction. SELECT ... FROM a WITH (TABLOCKX, HOLDLOCK) WHERE ...; -- Perform operations, including inserts and updates to table 'a'. The lock prevents interference. -- Commit the transaction, releasing the lock. COMMIT TRANSACTION; END;</code>
설명:
BEGIN TRANSACTION;
: 거래를 시작합니다. 트랜잭션 내의 모든 작업은 원자적으로 처리됩니다.SELECT ... FROM a WITH (TABLOCKX, HOLDLOCK);
: 이 SELECT
진술은 매우 중요합니다. TABLOCKX
테이블에 배타적 잠금 장치가 설정되어 있는지 확인합니다a
. HOLDLOCK
거래가 완료될 때까지 잠금을 유지합니다.a
에 대한 모든 수정(삽입, 업데이트, 삭제)은 배타적 잠금의 보호 하에 수행됩니다.COMMIT TRANSACTION;
: 트랜잭션을 커밋합니다. 여기에서 a
테이블의 잠금이 해제되어 다른 프로세스가 액세스할 수 있습니다. 오류가 발생하면 ROLLBACK TRANSACTION;
이 변경 사항을 취소하고 잠금을 해제합니다.이 트랜잭션 기반 접근 방식은 저장 프로시저가 일관되게 잠긴 테이블에서 작동하도록 보장하여 동시 액세스로 인한 데이터 손상을 방지합니다. 오류 시나리오에서도 데이터 무결성을 보장하려면 적절한 TRY...CATCH
블록과 ROLLBACK
을 사용하여 잠재적인 예외를 처리해야 합니다.
위 내용은 SQL Server에서 저장 프로시저 실행 중 테이블 잠금을 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!