인프런 커뮤니티 질문&답변
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”가 아닌 모든 when과 time_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 고유 인덱스 관련 질문
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.




