인프런 커뮤니티 질문&답변

초보개발님의 프로필 이미지
초보개발

작성한 질문수

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

DB 락 - 변경

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

작성

·

265

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 쿼리는 실행을할수 없다고 보면 될까요??

답변 1

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 초보개발님

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

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

감사합니다.

초보개발님의 프로필 이미지
초보개발

작성한 질문수

질문하기