🤍 전 강의 25% 할인 중 🤍

2024년 상반기를 돌아보고 하반기에도 함께 성장해요!
인프런이 준비한 25% 할인 받으러 가기 >>

  • 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

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

22.06.09 23:48 작성 조회수 222

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가 실행됩니다.

감사합니다.

채널톡 아이콘