강의

멘토링

커뮤니티

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

김도균님의 프로필 이미지
김도균

작성한 질문수

[매일 완독 챌린지] 저자와 함께하는 <FastAPI로 기획에서 출시까지>

8.5절 : 캘린더 예약 가져오기 API 구현하기 (p321~p338)

4주 3회차 과제

해결된 질문

작성

·

27

0

PostgreSQL의 Partial Unique Index의 기능을 활용하면 attendance_status 모델필드의 값이 cancelled 된 경우를 제외한 모든 동일 일자와 동일 타임슬롯인 경우를 중복으로 간주하는 제약을 구현 할 수 있습니다.

 

__table_args__ = (
        Index(
            "uq_active_booking_when_timeslot",
            "when",
            "time_slot_id",
            unique=True,
            postgresql_where=text("attendance_status <> 'CANCELLED'"),
        ),
    )

postgresql 일 경우, attendance_status 가 'CANCELLED' 가 아닌 모든 when + time_slot_id 조합에 고윳값 제약을 걸어줍니다.

답변 2

0

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

수고하셨습니다. 🙂

0

안녕하세요, 인프런 AI 인턴입니다. 김도균님.

PostgreSQL의 Partial Unique Index를 활용하여 특정 조건에서 중복을 방지하는 방법에 대해 잘 설명해 주셨습니다. 이 방법은 attendance_status 필드가 ‘CANCELLED’가 아닐 경우에만 제한을 걸어 중복 예약을 방지하는 전략입니다. 빠르게 설명드리겠습니다:

Partial Unique Index의 장점

  • 효율적인 중복 방지: 예약이 취소되지 않은 상황에서만 중복을 체크하게 하여, 필요에 따라 보다 효율적인 데이터베이스 활용이 가능합니다.

  • 특정 조건 제외: 특정한 비즈니스 로직, 예를 들어 예약 상태가 ‘취소됨’일 경우를 제외하고 중복을 허용하는 경우에 유리합니다.

코드 설명

아래의 코드는 PostgreSQL에서 attendance_status가 “CANCELLED”가 아닌 모든 whentime_slot_id 조합에 대해 고유성을 보장하는 인덱스를 설정합니다:

__table_args__ = (
    Index(
        "uq_active_booking_when_timeslot",
        "when",
        "time_slot_id",
        unique=True,
        postgresql_where=text("attendance_status <> 'CANCELLED'"),
    ),
)

이를 통해 설정된 제약은 중복 예약을 방지하면서도 ‘CANCELLED’ 상태의 예약에 대해서는 무시되고, 따라서 이러한 예외를 잘 처리할 수 있습니다.

추가 참고사항

  • PostgreSQL에서 이러한 기능을 활용할 수 있으나, 다른 데이터베이스에서는 같은 기능이 지원되지 않을 수 있어 보완적인 로직이 필요할 수 있습니다.

  • 이러한 정책을 실제 운영 환경에 도입할 때는 트래픽 상황이나 비즈니스 로직의 변화를 고려하여 추가 조율이 필요할 수 있습니다.

또한, 관련된 다른 수강생들의 질문과 참고 내용을 보시려면 다음 URL을 참고해 보실 수 있습니다:
- PostgreSQL 고유 인덱스 관련 질문

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

김도균님의 프로필 이미지
김도균

작성한 질문수

질문하기