inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

4주 3회차 과제

해결된 질문

49

김도균

작성한 질문수 6

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 조합에 고윳값 제약을 걸어줍니다.

python aws tdd FastAPI 북-챌린지

답변 2

0

한날

수고하셨습니다. 🙂

0

인프런 AI 인턴

안녕하세요, 인프런 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 고유 인덱스 관련 질문

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

4주 1회차 과제

0

44

2

4주 5회차 과제

0

44

1

4주 5회차 과제 제출

0

52

2

4주 4회차 과제 제출

0

62

2

351쪽 질문

0

52

2

refresh() 메서드와 픽스처에 대해 질문이 있습니다.

0

59

2

4주 2회차 과제 질문

0

57

3

4주 1회차 과제

0

53

2

4주 1회차 과제

0

44

2

4주 3회차 과제

0

55

2

4주 1회차 과제

0

52

2

4주 3회차 과제

0

38

1

4주 5회차 과제

0

38

2

4주 1회차 과제

0

29

2

4주 1회차 과제

0

25

2

4주 4회차 과제 제출

0

36

2

4주 1회차 과제 제출합니다.

0

43

1

4주 2회차 과제

0

49

1

patch 요청시 payload가 넘어가지 않습니다.

0

58

3

4주 1회차 과제

3

118

2

페이지 144 코드 문의

0

61

3

책과 github 코드가 다릅니다 p130

0

50

2

120페이지 코드 질문드립니다.

0

48

2

테스팅과 학습법의 관계 (?)

0

67

2