시나리오:
저장 프로시저(프로시저 A)는 업데이트를 수행하기 위해 테이블 'a'에 대한 단독 액세스가 필요합니다. SSRS(SQL Server Reporting Services)의 보고서는 불일치를 방지하기 위해 프로시저 A가 완료된 후에만 'a'의 데이터를 표시해야 합니다.
해결책:
이를 보장하는 가장 효과적인 방법은 트랜잭션과 적절한 잠금 힌트를 사용하는 것입니다.
코드 예:
<code class="language-sql">CREATE PROCEDURE ProcedureA AS BEGIN BEGIN TRANSACTION; -- Initiate a transaction SELECT ... FROM a WITH (XLOCK, HOLDLOCK); -- Exclusive lock (XLOCK) and hold the lock until the transaction ends (HOLDLOCK) WHERE ...; -- Perform operations not directly involving table 'a' here... -- Update table 'a' ... COMMIT TRANSACTION; -- Commit the transaction, releasing the lock END;</code>
설명:
BEGIN TRANSACTION;
: 거래를 시작합니다. 트랜잭션 내의 모든 작업은 단일 작업 단위로 처리됩니다.SELECT ... FROM a WITH (XLOCK, HOLDLOCK);
: 이 SELECT
문은 결정적으로 XLOCK
힌트를 사용하여 테이블 'a'에 대한 배타적 잠금을 획득합니다. HOLDLOCK
여러 문에서도 트랜잭션이 완료될 때까지 잠금이 유지되도록 합니다. 이렇게 하면 프로시저 A가 실행되는 동안 다른 프로세스가 'a'를 읽거나 쓸 수 없습니다.-- Perform operations not directly involving table 'a' here...
: 여기에서 다른 작업을 수행할 수 있습니다.-- Update table 'a' ...
: 테이블 'a'에 대한 업데이트는 트랜잭션 내에서 수행됩니다.COMMIT TRANSACTION;
: 트랜잭션이 커밋되어 변경 사항이 영구적으로 적용되고 테이블 'a'에 대한 배타적 잠금이 해제됩니다. 오류가 발생하면 ROLLBACK TRANSACTION;
을 사용하여 변경 사항을 취소하고 잠금을 해제해야 합니다.이 접근 방식은 저장 프로시저가 실행되는 동안 테이블에 대한 동시 액세스를 방지하여 데이터 무결성을 보장합니다. 그러면 절차가 완료된 후 SSRS 보고서에 업데이트된 데이터가 정확하게 반영됩니다.
위 내용은 저장 프로시저가 완료될 때까지 SQL Server 테이블이 잠긴 상태로 유지되도록 하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!