>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 낙관적 잠금을 어떻게 구현할 수 있습니까?

MySQL에서 낙관적 잠금을 어떻게 구현할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-26 20:39:30533검색

 How Can Optimistic Locking Be Implemented in MySQL?

MySQL의 낙관적 잠금

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.