Locking은 데이터베이스에서 동시성을 관리하는 중요한 메커니즘으로, 여러 트랜잭션이 데이터에 접근할 때 데이터 무결성을 보장하기 위해 사용됩니다. Spring Data JPA에서는 @Lock 어노테이션을 사용하여 쿼리 메서드나 CRUD 메서드에 잠금 모드를 지정할 수 있습니다. 아래에서 이를 자세히 설명하겠습니다.
1. 쿼리 메서드에서 Lock 모드 정의하기
쿼리 메서드에 @Lock 어노테이션을 사용하여 사용할 잠금 모드를 지정할 수 있습니다. 예를 들어, LockModeType.READ를 사용하면 해당 쿼리가 읽기 전용 잠금으로 실행됩니다. 이렇게 하면 다른 트랜잭션에서 동일한 데이터에 대한 변경 작업을 할 수 없게 되어, 데이터 무결성이 유지됩니다.
예시 1: 쿼리 메서드에서 Lock 메타데이터 정의하기
interface UserRepository extends Repository<User, Long> {
// 일반 쿼리 메서드
@Lock(LockModeType.READ)
List<User> findByLastname(String lastname);
}
위의 코드에서 findByLastname 메서드는 LockModeType.READ 잠금을 사용하도록 설정되었습니다. 이 메서드가 호출되면 해당 쿼리는 읽기 잠금을 설정하고, 다른 트랜잭션에서 해당 사용자 정보를 변경하는 것을 방지합니다.
2. CRUD 메서드에서 Lock 모드 정의하기
CRUD 메서드에서도 잠금 메타데이터를 정의할 수 있습니다. 이를 위해 해당 메서드를 repository 인터페이스에서 재정의하고, @Lock 어노테이션을 추가합니다.
예시 2: CRUD 메서드에서 Lock 메타데이터 정의하기
interface UserRepository extends Repository<User, Long> {
// CRUD 메서드의 재정의
@Lock(LockModeType.READ)
List<User> findAll();
}
위 코드에서는 findAll() 메서드를 재정의하면서 @Lock(LockModeType.READ)를 추가했습니다. 이를 통해 findAll() 메서드 호출 시 전체 사용자의 데이터를 읽을 때 읽기 잠금이 적용됩니다. 이 경우 다른 트랜잭션에서 사용자의 데이터에 대한 수정이 불가능해지므로, 데이터의 일관성을 보장할 수 있습니다.
LockModeType의 종류
Spring Data JPA에서 사용할 수 있는 LockModeType의 종류는 다음과 같습니다:
- LockModeType.READ: 읽기 잠금으로, 다른 트랜잭션에서 수정할 수 없게 합니다.
- LockModeType.WRITE: 쓰기 잠금으로, 해당 데이터에 대한 모든 접근을 차단합니다.
- LockModeType.OPTIMISTIC: 낙관적 잠금으로, 데이터 변경 시점에 버전 체크를 통해 충돌을 감지합니다.
- LockModeType.OPTIMISTIC_FORCE_INCREMENT: 낙관적 잠금이며, 항상 버전 번호를 증가시킵니다.
- LockModeType.PESSIMISTIC_READ: 비관적 읽기 잠금으로, 다른 트랜잭션에서 해당 데이터를 수정할 수 없게 합니다.
- LockModeType.PESSIMISTIC_WRITE: 비관적 쓰기 잠금으로, 다른 트랜잭션에서 해당 데이터를 읽거나 수정할 수 없게 합니다.
이처럼 Spring Data JPA의 @Lock 어노테이션을 통해 트랜잭션 내에서 데이터 접근에 대한 잠금을 설정할 수 있습니다. 이를 통해 여러 트랜잭션이 동시에 같은 데이터에 접근할 때 발생할 수 있는 문제를 예방하고, 데이터 무결성을 유지할 수 있습니다.
'JPA > Spring JPA Official' 카테고리의 다른 글
Auditing (0) | 2024.12.02 |
---|---|
Transactionality (0) | 2024.12.02 |
Projections (0) | 2024.12.02 |
Query Creation (0) | 2024.12.02 |
Defining Query Methods (1) | 2024.12.02 |