본문 바로가기

설계

[파이썬] 저장소 패턴 (Repository Pattern) 에 대해서

파이썬에서 Repository Pattern은 데이터 저장소의 독립성을 보장하고 비즈니스 로직을 데이터 액세스 코드로부터 분리하는 디자인 패턴입니다.

Repository Pattern을 사용하면 데이터베이스, 파일 시스템 또는 다른 데이터 저장소와 같은 데이터 저장소를 변경하더라도 비즈니스 로직의 변경 없이 쉽게 전환할 수 있습니다.

이 패턴은 데이터 액세스 계층과 비즈니스 로직 계층 사이의 의존성을 제거하여, 코드를 보다 관리하기 쉽게 만들고, 유지 보수성을 높이며, 코드 재사용성을 높이는 데 도움이 됩니다.

 

1. 구성 요소

 

Repository Pattern은 다음과 같은 요소로 이루어집니다.

  • Interface: Repository 인터페이스는 데이터 액세스 계층과 비즈니스 로직 계층 간의 상호 작용을 정의합니다. 이 인터페이스는 특정 데이터 저장소와 독립적이어야 하므로 다른 저장소에서도 재사용이 가능합니다.
  • Implementation: Repository 인터페이스를 구현하는 클래스입니다. 이 클래스는 실제 데이터 저장소와 상호 작용하는 코드를 구현합니다.
  • Service: Service는 비즈니스 로직을 처리하는 계층입니다. 데이터 액세스 코드를 호출하지 않고 Repository 인터페이스를 사용하여 데이터를 가져옵니다.
  • Entity: Entity는 Repository 패턴을 사용하여 데이터베이스에 저장되는 객체입니다. Entity는 비즈니스 로직에서 사용되는 객체이며, 데이터 액세스와 관련이 없습니다.


예를 들어, 만약 데이터베이스에서 사용자 정보를 가져와야 하는 경우, Repository 인터페이스를 구현하여 데이터베이스에서 사용자 정보를 가져오는 코드를 구현합니다. 그런 다음 Service 계층에서 이 인터페이스를 사용하여 사용자 정보를 가져올 수 있습니다.

이렇게 하면 데이터 액세스 계층과 비즈니스 로직 계층이 분리되어 유지 보수성이 높아지며, 데이터 저장소를 변경할 경우에도 비즈니스 로직의 변경 없이 전환할 수 있습니다.


2. 예제 코드

다음은 파이썬에서 Repository Pattern을 사용한 간단한 예제 코드입니다.

 

# Repository Interface
class UserRepository:
    def get_user(self, user_id: int) -> dict:
        pass

# Repository Implementation
class UserDBRepository(UserRepository):
    def get_user(self, user_id: int) -> dict:
        # Database code to get user by user_id
        user_data = {"id": user_id, "name": "John Doe", "email": "johndoe@example.com"}
        return user_data

# Service
class UserService:
    def __init__(self, repository: UserRepository):
        self.repository = repository

    def get_user(self, user_id: int) -> dict:
        user_data = self.repository.get_user(user_id)
        return user_data

# Usage
repository = UserDBRepository()
service = UserService(repository)
user_data = service.get_user(1)
print(user_data)  # {"id": 1, "name": "John Doe", "email": "johndoe@example.com"}


위 예제에서는 UserRepository 인터페이스를 정의하고, UserDBRepository 클래스에서 이 인터페이스를 구현합니다. UserService 클래스에서는 UserRepository 인터페이스를 사용하여 get_user 메서드를 호출하고, 이를 통해 UserDBRepository 클래스의 get_user 메서드를 호출합니다.

이렇게 하면 UserService 클래스에서는 데이터베이스와 직접적으로 상호 작용하지 않고, UserRepository 인터페이스를 통해 데이터 액세스를 처리합니다. 이를 통해 데이터 액세스 계층과 비즈니스 로직 계층을 분리하고, 코드 유지 보수성과 재사용성을 높일 수 있습니다.