MySQL은 기본적으로 낙관적 잠금을 지원하지 않지만 표준 SQL 구성 및 코드 논리를 통해 구현할 수 있습니다. .
잠금 접근 방식 없음:
이 접근 방식에서는 명시적 잠금이 사용되지 않습니다. 그러나 여러 사용자가 동일한 데이터를 동시에 업데이트하는 경우 데이터 일관성이 보장되지 않습니다.
SELECT data from theTable WHERE iD = @theId; {code that calculates new values} UPDATE theTable SET val1 = @newVal1, val2 = @newVal2 WHERE iD = @theId;
낙관적 잠금 접근 방식:
이 접근 방식에는 업데이트. 일반적으로 행 버전 관리 또는 동일성 검사에 의해 결정되는 수정이 발생하면 업데이트가 거부됩니다.
SELECT iD, val1, val2 FROM theTable WHERE iD = @theId; {code that calculates new values} UPDATE theTable SET val1 = @newVal1, val2 = @newVal2 WHERE iD = @theId AND val1 = @oldVal1 AND val2 = @oldVal2; {if AffectedRows == 1 } {go on with your other code} {else} {decide what to do since it has gone bad... in your code} {endif}
버전 관리 낙관적 잠금:
낙관적 잠금과 유사합니다. 접근 방식에서 이 기술은 버전 열을 사용하여 수정 사항을 확인합니다.
SELECT iD, val1, val2, version FROM theTable WHERE iD = @theId; {code that calculates new values} UPDATE theTable SET val1 = @newVal1, val2 = @newVal2, version = version + 1 WHERE iD = @theId AND version = @oldversion; {if AffectedRows == 1 } {go on with your other code} {else} {decide what to do since it has gone bad... in your code} {endif}
트랜잭션 및 격리 수준:
트랜잭션은 낙관적 잠금과 함께 사용하여 다음을 보장할 수 있습니다. 데이터 일관성. 그러나 트랜잭션 격리 수준의 선택은 낙관적 잠금의 효율성에 영향을 미칠 수 있습니다.
테스트 및 확인:
낙관적 잠금이 올바르게 구현되었는지 확인하려면 다음을 수행하는 것이 좋습니다. 다양한 시나리오와 격리 수준을 사용하여 철저한 테스트 및 검증을 수행합니다.
위 내용은 MySQL에서 낙관적 잠금을 어떻게 구현할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!