inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 1편 - 데이터 접근 핵심 원리

DB 락 - 개념 이해

세션1이 롤백을 하게 되면 세션2는 잘못된 데이터를 수정하는 문제가 발생한다는 의미

해결된 질문

122

11 1

작성한 질문수 147

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]

 

아래는 강의 자료에 있는 내용입니다.
------------------------------------------

세션1이 트랜잭션을 시작하고 데이터를 수정하는 동안 아직 커밋을 수행하지 않았는데, 세션2에서 동시에 같은 데이터 를 수정하게 되면 여러가지 문제가 발생한다. 바로 트랜잭션의 원자성이 깨지는 것이다. 여기에 더해서 세션1이 중간에 롤백을 하게 되면 세션2는 잘못된 데이터를 수정하는 문제가 발생한다.

------------------------------------------

 

money=10000인 상태에서


세션1이 money를 5000으로 바꾼다고 하더라도 커밋을 하지 않는다면, 세션2가 보고 있는 money는 여전히 10000인 거고 10000에 접근하는 거 맞나요? 그렇다면 세션1이 롤백을 하더라도 세션2은 기존 10000을 수정하고 있는 거니 잘못된 데이터를 수정하는 건 아니지 않나요? 위에 굵게 표시한 부분 어떤 의미인지 궁금합니다. 아니면 위에 있는 설명은 커밋되지 않는 데이터에 접근하는 경우라고 가정하는 건가요?

spring mvc spring-jdbc

답변 2

2

김영한

안녕하세요. 11 1님

세션1이 데이터를 수정하고 있는데, 그 사이에 만약 세션2가 10000원인 데이터를 1원으로 변경하면 세션1이 수정하는 데이터에도 문제가 발생하겠지요?

이런 문제들 때문에 락이라는 개념이 필요합니다.

감사합니다.

1

11 1

답변 감사합니다

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

질문해 주신 내용을 바탕으로 스프링 데이터 접근과 관련된 문제에 대해 설명드리겠습니다.

세션1이 데이터를 수정 중이면서 아직 커밋을 하지 않은 상태에서, 세션1의 수정 결과를 세션2가 볼 수 있는지는 사용하는 데이터베이스의 격리 수준(Isolation Level)에 따라 달라집니다. 대부분의 데이터베이스 시스템에서 기본 설정은 다른 트랜잭션에서 커밋되지 않은 데이터는 보이지 않게 하는 ‘READ COMMITTED’입니다.

따라서 세션2는 세션1이 커밋하지 않았기 때문에 세션1이 수정한 데이터(money를 5000으로 바꿈)를 볼 수 없고, 여전히 money=10000인 것으로 인식하여 작업을 진행합니다.

세션1이 롤백을 하게 되면, 세션1에 의한 모든 변경사항이 취소되어 데이터베이스의 상태는 세션1이 트랜잭션을 시작하기 전 상태(money=10000)로 돌아갑니다. 이 경우, 세션2는 ‘잘못된 데이터’를 수정하는 것이 아니라, 실제로 데이터베이스에 반영된 데이터의 상태를 기반으로 작업을 진행하는 것입니다.

하지만 여기서 “잘못된 데이터를 수정한다”는 표현은 세션1이 롤백될 경우, 세션2가 세션1의 변경사항을 고려 없이 데이터를 수정하게 되어, 세션1의 의도와 무관하게 데이터가 변경될 수 있다는 점을 의미할 수 있습니다. 이것은 동시성 제어와 데이터의 일관성 유지 측면에서 중요한 문제를 제기합니다.

그러나 커밋되지 않은 데이터에 대한 접근 여부는 데이터베이스의 격리 수준 설정과 특정 상황에 따라 다를 수 있으며, 이는 트랜잭션 관리와 동시성 제어에 대한 깊은 이해를 요구하는 부분입니다. 데이터베이스와 애플리케이션의 격리 수준을 적절히 설정하여, 이런 문제를 방지할 수 있는 방법을 고려해야 합니다.

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

32

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

51

1

jdbc 학습하다 궁금해서 질문드려요

0

82

1

정상이체와 이체중 예외발생 차이

0

68

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

88

1

순수한 서비스 계층에 대한 의문???

0

82

2

3_4test, 4test 자동 리소스 안됨

0

58

2

데이터베이스 선택 관련 질문.

0

68

2

after 메서드 사용 유무

0

57

2

데이터베이스 접근 및 DB 락

0

55

1

@SpingBootTest, @TestConfiguration

0

56

1

Read Committed 격리 수준 사용 관련 질문

0

48

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

66

2

커리큘럼 관련 질문

0

76

1

서비서 계층 스프링 프레임워크 사용

0

88

1

validation(toMember)의 위치

0

83

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

165

2

member 상수 질문

0

121

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

153

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

109

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

100

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

98

1

강의 14분쯤 Exception 질문

0

115

2