JSONField 및 Pydantic을 사용하여 Django에서 유연한 데이터 모델을 구축하는 방법
이 기사에서는 Django의 JSONField(JSON 및 JSONB 래퍼)를 사용하여 반구조화된 데이터를 모델링하는 방법과 해당 데이터에 스키마를 적용하는 방법을 안내하겠습니다. Pydantic을 사용하는 데이터 - Python 웹 개발자에게 자연스러운 접근 방식입니다.
유연한 유형 정의
예를 들어 거래 테이블과 같이 결제를 처리하는 시스템을 생각해 보겠습니다. 다음과 같이 표시됩니다.
from django.db import models class Transaction(models.Model): # Other relevant fields... payment_method = models.JSONField(default=dict, null=True, blank=True)
우리는 Payment_method 필드에 중점을 두고 있습니다. 실제 상황에서는 기존의 결제 처리 방법을 사용합니다.
신용카드
페이팔
지금 구매하고 나중에 결제
암호화폐
우리 시스템은 일관되고 검증 가능한 구조를 유지하면서 각 결제 방법에 필요한 특정 데이터를 저장할 수 있도록 조정 가능해야 합니다.
Pydantic을 사용하여 다양한 결제 방법에 대한 정확한 스키마를 정의합니다.
from typing import Optional from pydantic import BaseModel class CreditCardSchema(BaseModel): last_four: str expiry_month: int expiry_year: int cvv: str class PayPalSchema(BaseModel): email: EmailStr account_id: str class CryptoSchema(BaseModel): wallet_address: str network: Optional[str] = None class BillingAddressSchema(BaseModel): street: str city: str country: str postal_code: str state: Optional[str] = None class PaymentMethodSchema(BaseModel): credit_card: Optional[CreditCardSchema] = None paypal: Optional[PayPalSchema] = None crypto: Optional[CryptoSchema] = None billing_address: Optional[BillingAddressSchema] = None
이 접근 방식은 다음과 같은 몇 가지 중요한 이점을 제공합니다.
한 번에 하나의 결제 방법만 Null이 아닌 값을 가질 수 있습니다.
복잡한 데이터베이스 마이그레이션 없이 확장이나 수정이 쉽습니다.
모델 수준에서 데이터 무결성을 보장합니다.
결제 방법 필드에 스키마를 적용하기 위해 Pydantic 모델을 활용하여 필드에 전달된 모든 데이터가 정의한 스키마와 일치하는지 확인합니다.
from typing import Optional, Mapping, Type, NoReturn from pydantic import ValidationError as PydanticValidationError from django.core.exceptions import ValidationError def payment_method_validator(value: Optional[dict]) -> Optional[Type[BaseModel] | NoReturn]: if value is None: return if not isinstance(value, Mapping): raise TypeError("Payment method must be a dictionary") try: PaymentMethodSchema(**value) except (TypeError, PydanticValidationError) as e: raise ValidationError(f"Invalid payment method: {str(e)}")
여기서 Pydantic이 유효성을 검사할 수 있도록 유효성 검사기에 입력된 데이터가 올바른 유형인지 확인하기 위해 몇 가지 검사를 수행합니다. 우리는 null 허용 값에 대해 아무 작업도 수행하지 않으며 전달된 값이 Dict 또는 OrderedDict와 같은 매핑 유형의 하위 클래스가 아닌 경우 유형 오류를 발생시킵니다.
생성자에 전달한 값을 사용하여 Pydantic 모델의 인스턴스를 생성할 때. 값의 구조가 PaymentMethodSchema에 대해 정의된 스키마에 맞지 않으면 Pydantic은 유효성 검사 오류를 발생시킵니다. 예를 들어 PayPalSchema의 이메일 필드에 잘못된 이메일 값을 전달하면 Pydantic은 다음과 같은 유효성 검사 오류를 발생시킵니다.
ValidationError: 1 validation error for PaymentMethodSchema paypal.email value is not a valid email address: An email address must have an @-sign. [type=value_error, input_value='Check me out on LinkedIn: https://linkedin.com/in/daniel-c-olah', input_type=str]
이 유효성 검사는 두 가지 방법으로 시행할 수 있습니다.
-
사용자 정의 검증 방법
저장 프로세스 중에 결제 방법이 예상 스키마와 일치하는지 확인하기 위해 유효성 검사 기능을 호출합니다.
from django.db import models class Transaction(models.Model): # ... other fields ... payment_method = models.JSONField(null=True, blank=True) def save(self, *args, **kwargs): # Override save method to include custom validation payment_method_validator(self.payment_method) super().save(*args, **kwargs)
로그인 후 복사이 접근 방식은 효과적이지만 Django에서는 번거롭고 덜 관용적이 될 수 있습니다. 코드를 더 깔끔하게 만들기 위해 동일한 작업을 수행하는 클래스 메소드로 함수를 대체할 수도 있습니다.
-
필드 유효성 검사기 사용
이 방법은 Django에 내장된 필드 유효성 검사 메커니즘을 활용합니다.
from django.db import models class Transaction(models.Model): # Other relevant fields... payment_method = models.JSONField(default=dict, null=True, blank=True)
로그인 후 복사로그인 후 복사이 접근 방식은 Payment_method 필드에 저장된 값에 대한 유연성과 제어의 균형을 유지합니다. 이를 통해 해당 분야의 기존 데이터 무결성을 손상시키지 않고 향후 요구 사항 변화에 적응할 수 있습니다. 예를 들어 Paystack 스키마에 Paystack ID 필드를 포함할 수 있습니다. 복잡한 데이터베이스 마이그레이션을 처리할 필요가 없으므로 이러한 변경은 원활하게 이루어질 것입니다.
향후에는 번거로움 없이 나중에 결제 방식을 추가할 수도 있습니다. 필드 유형도 변경될 수 있으며 정수 기본 키에서 UUID 기본 키로 마이그레이션할 때 발생하는 것과 같은 데이터베이스 필드 마이그레이션 제약 조건에 직면하지 않습니다. 개념을 완전히 이해하려면 여기에서 전체 코드를 확인하세요.
비정규화
비정규화에는 성능과 확장성을 최적화하기 위해 여러 문서 또는 컬렉션에 걸쳐 의도적으로 데이터를 복제하는 작업이 포함됩니다. 이 접근 방식은 기존 관계형 데이터베이스에 사용되는 엄격한 정규화와 대조되며, NoSQL 데이터베이스는 유연한 문서 중심 스토리지 패러다임을 도입하여 비정규화를 대중화하는 데 중요한 역할을 했습니다.
제품과 주문에 대한 별도의 테이블이 있는 전자상거래 시나리오를 생각해 보세요. 고객이 주문할 때 장바구니에 포함된 제품 세부 정보의 스냅샷을 캡처하는 것이 중요합니다. 업데이트나 삭제로 인해 시간이 지남에 따라 변경될 수 있는 현재 제품 기록을 참조하는 대신 제품 정보를 주문 내에 직접 저장합니다. 이를 통해 주문이 원래의 맥락과 무결성을 유지하고 구매 당시 제품의 정확한 상태를 반영하도록 보장합니다. 비정규화는 이러한 일관성을 달성하는 데 중요한 역할을 합니다.
한 가지 가능한 접근 방식은 주문 테이블의 일부 제품 필드를 복제하는 것입니다. 그러나 이 방법은 확장성 문제를 야기하고 주문 스키마의 응집력을 손상시킬 수 있습니다. 보다 효과적인 솔루션은 관련 제품 필드를 JSON 구조로 직렬화하여 주문이 외부 쿼리에 의존하지 않고 제품의 자체 포함된 기록을 유지할 수 있도록 하는 것입니다. 다음 코드는 이 기술을 보여줍니다.
from typing import Optional from pydantic import BaseModel class CreditCardSchema(BaseModel): last_four: str expiry_month: int expiry_year: int cvv: str class PayPalSchema(BaseModel): email: EmailStr account_id: str class CryptoSchema(BaseModel): wallet_address: str network: Optional[str] = None class BillingAddressSchema(BaseModel): street: str city: str country: str postal_code: str state: Optional[str] = None class PaymentMethodSchema(BaseModel): credit_card: Optional[CreditCardSchema] = None paypal: Optional[PayPalSchema] = None crypto: Optional[CryptoSchema] = None billing_address: Optional[BillingAddressSchema] = None
이전 섹션에서 대부분의 개념을 다루었으므로 이 모든 것에서 Pydantic의 역할을 이해하기 시작해야 합니다. 위의 예에서는 Pydantic을 사용하여 주문에 연결된 제품 목록을 확인합니다. 제품 구조에 대한 스키마를 정의함으로써 Pydantic은 주문에 추가된 모든 제품이 예상 요구 사항을 충족하는지 확인합니다. 제공된 데이터가 스키마를 준수하지 않는 경우 Pydantic은 유효성 검사 오류를 발생시킵니다.
Django에서 JSONField 쿼리하기
Django 필드에서 검색을 수행하는 것과 동일한 방식으로 JSONField 키를 쿼리할 수 있습니다. 다음은 사용 사례에 따른 몇 가지 예입니다.
from typing import Optional, Mapping, Type, NoReturn from pydantic import ValidationError as PydanticValidationError from django.core.exceptions import ValidationError def payment_method_validator(value: Optional[dict]) -> Optional[Type[BaseModel] | NoReturn]: if value is None: return if not isinstance(value, Mapping): raise TypeError("Payment method must be a dictionary") try: PaymentMethodSchema(**value) except (TypeError, PydanticValidationError) as e: raise ValidationError(f"Invalid payment method: {str(e)}")
JSON 필드 필터링에 대해 자세히 알아보려면 설명서를 확인하세요.
결론
PostgreSQL에서 JSON 및 JSONB를 사용하면 관계형 데이터베이스에서 반구조화된 데이터 작업에 탁월한 유연성을 제공합니다. Pydantic 및 Django의 JSONField와 같은 도구는 데이터 구조에 대한 규칙을 적용하여 정확성을 유지하고 변경 사항에 적응하는 것을 더 쉽게 해줍니다. 그러나 이러한 유연성은 신중하게 사용해야 합니다. 적절한 계획이 없으면 시간이 지남에 따라 데이터가 변경되므로 성능이 저하되거나 불필요한 복잡성이 발생할 수 있습니다.
Django에서 필드 유효성 검사기는 full_clean()이 명시적으로 호출될 때만 트리거됩니다. 이는 일반적으로 Django Forms를 사용하거나 DRF 직렬 변환기에서 is_valid()를 호출할 때 발생합니다. 자세한 내용은 Django 유효성 검사기 문서를 참조하세요.
이 문제를 해결하기 위한 보다 진보된 접근 방식은 내부적으로 JSON 데이터의 직렬화 및 유효성 검사를 모두 처리하기 위해 Pydantic을 통합하는 사용자 정의 Django 필드를 구현하는 것입니다. 이는 전용 기사를 보장하지만 지금은 이 문제에 대한 기성 솔루션을 제공하는 라이브러리를 탐색할 수 있습니다(예: django-pydantic-jsonfield
).위 내용은 JSONField 및 Pydantic을 사용하여 Django에서 유연한 데이터 모델을 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Python은 데이터 과학, 웹 개발 및 자동화 작업에 적합한 반면 C는 시스템 프로그래밍, 게임 개발 및 임베디드 시스템에 적합합니다. Python은 단순성과 강력한 생태계로 유명하며 C는 고성능 및 기본 제어 기능으로 유명합니다.

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.

2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

Python은 배우고 사용하기 쉽고 C는 더 강력하지만 복잡합니다. 1. Python Syntax는 간결하며 초보자에게 적합합니다. 동적 타이핑 및 자동 메모리 관리를 사용하면 사용하기 쉽지만 런타임 오류가 발생할 수 있습니다. 2.C는 고성능 응용 프로그램에 적합한 저수준 제어 및 고급 기능을 제공하지만 학습 임계 값이 높고 수동 메모리 및 유형 안전 관리가 필요합니다.

제한된 시간에 Python 학습 효율을 극대화하려면 Python의 DateTime, Time 및 Schedule 모듈을 사용할 수 있습니다. 1. DateTime 모듈은 학습 시간을 기록하고 계획하는 데 사용됩니다. 2. 시간 모듈은 학습과 휴식 시간을 설정하는 데 도움이됩니다. 3. 일정 모듈은 주간 학습 작업을 자동으로 배열합니다.

파이썬은 자동화, 스크립팅 및 작업 관리가 탁월합니다. 1) 자동화 : 파일 백업은 OS 및 Shutil과 같은 표준 라이브러리를 통해 실현됩니다. 2) 스크립트 쓰기 : PSUTIL 라이브러리를 사용하여 시스템 리소스를 모니터링합니다. 3) 작업 관리 : 일정 라이브러리를 사용하여 작업을 예약하십시오. Python의 사용 편의성과 풍부한 라이브러리 지원으로 인해 이러한 영역에서 선호하는 도구가됩니다.
