
동시성 제어 문제먼저 동시성 제어가 제대로 이루어지지 않았을 때 발생할 수 있는 문제들을 알아보자. Lost Update - 갱신 손실하나의 트랜잭션에서 갱신한 데이터 내용을 다른 트랜잭션이 덮어씀으로써 갱신이 무효화 되는 문제를 의미한다.초기 값이 `x = 1`데이터에 대해 두 트랜잭션이 동시에 실행된다고 생각해보자.트랜잭션 A : `x + 10`트랜잭션 B : `x + 20`트랜잭션 A가 먼저 실행되어 x = x + 10 연산을 통해 값을 `11`로 갱신한다.트랜잭션 A보다 조금 늦게 시작한 트랜잭션 B가 x = x + 20 연산을 통해 값을 `21`으로 갱신한다.결과적으로 x의 값은 21이되며 트랜잭션 A의 갱신은 손실된다.두 트랜잭션이 직렬로 실행되었다면 `x` 값은 31이 되어야 한다. 하지만 ..

트랜잭션이 나올 때마다 단골처럼 나오는 예시가 은행 송금 상황이다. 예를들어 예전에 친구에게 만원을 빌렸다가 갚는 상황을 생각해보자. 은행 어플을 열고 친구의 계좌번호와 만원을 입력하고 송금 버튼을 눌러서 내 계좌에서 돈이 빠져나갔다. 하지만 어떤 이유에서인지 친구의 계좌에는 만원이 입금되지 않았다. 일반적인 생각에서는 송금에 실패했다면 다시 내 계좌로 만원이 되돌아오는게 정상적이다. 트랜잭션은 이러한 정상적인 상황을 보장하기 위한 개념이다. 트랜잭션이란, 하나의 작업 단위로 간주되는 일련의 연산 또는 명령 집합을 의미한다. 위 예시로 생각하자면 하나의 작업이라는 것은 `송금`이 될 것이고 명령의 집합은 `{출금, 입금}`이 될 것이다. 즉, 내 계좌에서 만원이 빠지고 친구 계좌에 만원이 입금되는 모든 ..

운영체제에서 여러 스레드가 동일한 자원에 접근할 때 동시성 문제가 발생할 수 있는 것처럼 데이터베이스에서도 여러 트랜잭션이 동시에 실행되고 이 트랜잭션들이 동일한 자원에 접근할 때 동시성 문제가 발생한다. 이를위해 데이터베이스에서도 락을 제공해 여러 트랜잭션이 동시에 데이터를 처리할 때, 데이터의 무결성과 일관성을 보장할 수 있도록 돕는다. Lock의 수준Database Level전체 데이터베이스에 대한 락을 설정하는 가장 큰 범위의 락이다.관리 비용이 매우 적고 데이터베이스 백업 또는 복구와 같은 특정 유지보수 작업 시에 유용하다.하지만 동시성이 전혀 보장되지 않아 작업 중인 트랜잭션 외의 모든 트랜잭션은 대기해야한다.Table Level테이블 전체에 대해 락을 설정한다.매우 간단하고 관리 비용도 적다..