DB 락 획득 설정
406
작성한 질문수 44
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
아니오
[질문 내용]
안녕하세요.
트랜잭션을 시작한 후 CUD 쿼리를 사용하는 경우 자동으로 DB 락을 획득하게 되는걸까요?
혹시 원한다면 락을 걸지 않고 사용하는 설정도 있을 지 궁금합니다.
스프링을 사용할 때 @Lock 과 같은 애노테이션으로 락을 설정하는 것으로 기억하는데 설정을 하지 않아도 CUD 에서는 자동으로 락을 획득하게 되는걸까요?
답변 1
1
안녕하세요, 인프런 AI 인턴입니다. 프로그래밍 관련 질문에 답변드리겠습니다.
트랜잭션을 시작한 후 CUD (Create, Update, Delete) 쿼리를 사용하는 경우에는 일반적으로 DB 락을 자동으로 획득합니다. DBMS는 트랜잭션이 진행 중인 데이터에 대해서 락을 걸어 다른 트랜잭션이 접근하지 못하도록 합니다. 이를 통해 데이터의 일관성과 동시성을 보장할 수 있습니다.
스프링 프레임워크에서 사용되는 @Lock 애노테이션은 JPA (Java Persistence API)에서 제공하는 기능으로, 데이터베이스 레벨에서 락을 설정하는 기능을 사용할 수 있습니다. 하지만 이는 개발자가 직접 설정하는 것이며, 기본적으로 CUD 작업의 경우 DB 락을 자동으로 획득합니다.
따라서 일반적으로 프레임워크와 DBMS에서 자동으로 락을 설정하므로 따로 설정하지 않아도 CUD 작업에서는 락을 획득합니다.
더 자세한 설정 및 사용 방법은 해당 프레임워크나 DBMS의 문서나 공식 사이트를 참고하시면 도움이 될 것입니다. 언제나 질문해주세요. 감사합니다.
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
38
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
51
1
jdbc 학습하다 궁금해서 질문드려요
0
85
1
정상이체와 이체중 예외발생 차이
0
70
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
89
1
순수한 서비스 계층에 대한 의문???
0
83
2
3_4test, 4test 자동 리소스 안됨
0
59
2
데이터베이스 선택 관련 질문.
0
71
2
after 메서드 사용 유무
0
60
2
데이터베이스 접근 및 DB 락
0
57
1
@SpingBootTest, @TestConfiguration
0
58
1
Read Committed 격리 수준 사용 관련 질문
0
51
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
69
2
커리큘럼 관련 질문
0
78
1
서비서 계층 스프링 프레임워크 사용
0
89
1
validation(toMember)의 위치
0
84
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
166
2
member 상수 질문
0
124
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
154
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
110
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
116
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
103
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
98
1
강의 14분쯤 Exception 질문
0
116
2





