>  기사  >  데이터 베이스  >  동시 데이터베이스 작업으로 인해 어떤 문제가 발생할 수 있나요?

동시 데이터베이스 작업으로 인해 어떤 문제가 발생할 수 있나요?

王林
王林원래의
2020-06-20 09:32:218717검색

동시 데이터베이스 작업으로 인해 어떤 문제가 발생할 수 있나요?

데이터베이스의 동시 작업은 일반적으로 업데이트 손실 문제, 일관성 없는 분석 문제 및 "더티 데이터" 읽기 문제를 발생시킵니다.

관련 지식 포인트 소개:

트랜잭션은 동시성 제어의 기본 단위입니다.

(권장 관련 튜토리얼: mysql 튜토리얼)

동시 작업으로 인한 데이터 불일치

1. 업데이트 손실(Lost Update)

2. Phantom Read

4. "더티" 데이터 읽기(Dirty Read)

별도로 살펴보겠습니다.

수정 손실: 두 트랜잭션 T-1과 T-2가 동일한 데이터를 읽고 수정하여 제출 결과 T-2의 수정은 T-1의 제출 결과를 파괴하여 T-1의 수정 사항을 잃게 만듭니다. (수정-수정 충돌)

비반복 읽기: 트랜잭션 1이 특정 데이터를 읽고 트랜잭션 2가 이를 수정하며, 트랜잭션 1이 데이터를 다시 읽으면 이전 시간과 다른 값을 얻습니다(읽기-업데이트 충돌)

팬텀 읽기: 트랜잭션 T-1은 특정 조건에 따라 데이터베이스에서 특정 데이터 레코드를 읽고, 트랜잭션 T-2는 해당 레코드 중 일부를 삭제(삽입)합니다. T-1이 동일한 조건에 따라 데이터를 다시 읽으면 발견됩니다. 어떤 기록이 신비롭게 사라지는(나타나는) 것. (읽기-삽입/삭제 충돌)

더티 데이터: 트랜잭션 T-1은 특정 데이터를 수정하고 이를 디스크에 다시 씁니다. 트랜잭션 T-2가 동일한 데이터를 읽은 후 T-1은 어떤 이유로 취소됩니다. 1, 수정된 데이터는 원래 값으로 복원되고, T-2가 읽은 데이터는 데이터베이스의 데이터와 일치하지 않습니다. T-2가 읽은 데이터는 "더러운" 데이터, 즉 잘못된 데이터(수정- 읽기 충돌)

데이터 불일치: 동시 작업은 트랜잭션의 격리를 파괴하기 때문입니다

동시성 제어의 목적

은 한 사용자 트랜잭션의 실행이 다른 사용자 트랜잭션의 실행을 방해하지 않도록 올바른 방식으로 동시 작업을 예약하는 것입니다. 트랜잭션을 수행하여 데이터 불일치를 방지합니다.

위 내용은 동시 데이터베이스 작업으로 인해 어떤 문제가 발생할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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