inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

DB 락 - 변경

락 잡을 경우 조회가 안되는데요

328

초보개발

작성한 질문수 9

1

질문이 있습니다.
 
세션1에서 commit전 아래와 같이 쿼리를 날리고
```
set autocommit false; update member set money=500 where member_id = 'memberA';
```
 
세션2에서 아래와 같이 update와 select를 실행하는 쿼리를 날려보았습니다.
```
SET LOCK_TIMEOUT 60000; set autocommit false; update member set money=1000 where member_id = 'memberA';
 
select * from member;
```
 
이후 세션1에서 commit을 날리게 되면 세션2에서 순차적으로 update, select문이 실행 되는데 이건 세션1에서 락이 반납이 되서 모든 쿼리문이 실행된걸로 보면 되는걸까요??
그렇다면 commit 후 락이 반납되기 전까지는 어떠한 CRUD 쿼리는 실행을할수 없다고 보면 될까요??

spring

답변 1

1

김영한

안녕하세요. 초보개발님

세션2에서 update를 할 때 락을 획득하지 못했기 때문에 세션2는 대기하게 됩니다. 따라서 그 다음에 있는 select 구분에 진행 자체가 안된 것입니다.

참고로 세션2에서 select를 먼저 했다면 select가 실행됩니다.

감사합니다.

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

0

31

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

120

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