찾다
백엔드 개발파이썬 튜토리얼믹스인 및 주석을 사용하여 SQLAlchemy 모델 모듈화

Modularizing SQLAlchemy Models with Mixins and Annotations
확장 가능하고 유지 관리가 가능한 모델을 구축하려면 특히 여러 모델에서 공유 동작이나 공통 열 유형을 처리할 때 모듈식 접근 방식이 필요한 경우가 많습니다. 이번 블로그에서는 SQLAlchemy의 믹스인주석을 사용하여 모델을 모듈화하는 방법을 살펴보겠습니다.
   

왜 모듈화해야 합니까?

프로젝트 작업을 하다 보면 Created_at 및update_at 타임스탬프를 모델에 추가하거나 UUID 기본 키와 같은 공통 열 유형을 정의하는 등 반복적인 작업을 자주 접하게 됩니다. 이러한 문제를 별도의 구성 요소로 모듈화하면 다음과 같은 여러 가지 이점이 있습니다.
 
1. 재사용성: 공유 동작 및 열 정의를 여러 모델에서 사용할 수 있습니다.
2. 유지관리성: 한 곳의 변경 사항이 모든 종속 모델에 전파됩니다.
3. 가독성: 관심사를 명확하게 분리하면 코드를 더 쉽게 이해할 수 있습니다.

 

타임스탬프 믹스인 만들기

믹스인은 모델에 재사용 가능한 로직 또는 필드를 제공합니다. Create_at 및update_at 필드를 상속받는 모든 모델에 자동으로 추가하는 TimestampMixin을 정의해 보겠습니다.
 
파일: timestamp_mixin.py

from datetime import datetime
from sqlalchemy import Column, DateTime
from sqlalchemy.ext.declarative import declared_attr

class TimestampMixin:
    @declared_attr
    def created_at(cls):
        return Column(DateTime, default=datetime.utcnow, nullable=False)

    @declared_attr
    def updated_at(cls):
        return Column(DateTime, default=datetime.utcnow, onupdate=datetime.utcnow, nullable=False)
설명
  • @declared_attr: 속성이 상속 모델에 동적으로 추가되도록 합니다.
  • default 및 onupdate: 생성 및 업데이트에 대한 타임스탬프를 자동으로 설정합니다.

 

공통 주석 정의

Python의 Typing.Annotated를 통해 사용할 수 있는 SQLAlchemy의 Annotated 유형을 사용하면 재사용 가능한 열 속성을 정의할 수 있습니다. 예를 들어 UUID 기본 키 또는 특정 제약 조건이 있는 문자열 열을 정의할 수 있습니다.
 
파일: common_annotations.py

from typing import Annotated
from uuid import uuid4
from sqlalchemy import String
from sqlalchemy.dialects.postgresql import UUID
from sqlalchemy.orm import mapped_column

uuid4pk = 
    mapped_column(UUID(as_uuid=True), primary_key=True, default=uuid4, nullable=False)
]

name = Annotated[
    str,
    mapped_column(String(30), nullable=False)
]
설명
  • UUID 기본 키: uuid4pk 주석은 기본 키에 대한 범용 고유 식별자를 정의합니다.
  • 이름 열: 이름 주석은 최대 길이가 30자이고 NULL 값이 없는 문자열 열을 보장합니다.

 

믹스인과 주석을 사용하여 모델 구축

믹스인과 주석을 사용하면 구현을 간결하고 읽기 쉽게 유지하면서 공유 동작과 속성을 상속하는 모델을 정의할 수 있습니다.
 
파일: user.py

from datetime import datetime
from sqlalchemy import Column, DateTime
from sqlalchemy.ext.declarative import declared_attr

class TimestampMixin:
    @declared_attr
    def created_at(cls):
        return Column(DateTime, default=datetime.utcnow, nullable=False)

    @declared_attr
    def updated_at(cls):
        return Column(DateTime, default=datetime.utcnow, onupdate=datetime.utcnow, nullable=False)
설명
  • Declarative Base: Base는 모든 SQLAlchemy 모델의 기초 역할을 합니다.

 

이 접근 방식의 이점

1. 명확한 우려사항 분리

  • timestamp_mixin.py: 재사용 가능한 로직(예: 타임스탬프)이 포함되어 있습니다.
  • common_annotations.py: 공통 열 속성(예: UUID, 문자열)을 정의합니다.
  • user.py: 이러한 빌딩 블록을 콘크리트 모델로 결합합니다.

2. 유지보수 용이성

  • 타임스탬프 작동 방식을 변경하거나 열 제약 조건을 업데이트해야 하는 경우 timestamp_mixin.py 또는 common_annotations.py 파일만 수정하면 됩니다. 변경 사항은 모든 종속 모델에 자동으로 반영됩니다.

3. 확장성

  • 프로젝트가 성장함에 따라 이 구조를 사용하면 중복을 도입하지 않고도 새로운 동작이나 필드 유형을 더 쉽게 추가할 수 있습니다.

   

최종 생각

SQLAlchemy의 mixinsannotations를 사용하여 모델을 모듈화하는 것은 공유 기능과 속성을 처리하기 위한 좋은 전략입니다. 이 접근 방식은 중복을 줄일 뿐만 아니라 깔끔하고 유지 관리 가능한 코드에 대한 모범 사례에도 부합합니다.

위 내용은 믹스인 및 주석을 사용하여 SQLAlchemy 모델 모듈화의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Python Switch 문은 무엇입니까?Python Switch 문은 무엇입니까?Apr 30, 2025 pm 02:08 PM

이 기사는 버전 3.10에 도입 된 Python의 새로운 "매치"진술에 대해 논의하며, 이는 다른 언어로 된 문장과 동등한 역할을합니다. 코드 가독성을 향상시키고 기존 IF-ELIF-EL보다 성능 이점을 제공합니다.

파이썬의 예외 그룹은 무엇입니까?파이썬의 예외 그룹은 무엇입니까?Apr 30, 2025 pm 02:07 PM

Python 3.11의 예외 그룹은 여러 예외를 동시에 처리하여 동시 시나리오 및 복잡한 작업에서 오류 관리를 향상시킵니다.

파이썬의 기능 주석이란 무엇입니까?파이썬의 기능 주석이란 무엇입니까?Apr 30, 2025 pm 02:06 PM

Python의 기능 주석은 유형 확인, 문서 및 IDE 지원에 대한 기능에 메타 데이터를 추가합니다. 코드 가독성, 유지 보수를 향상 시키며 API 개발, 데이터 과학 및 라이브러리 생성에 중요합니다.

파이썬의 단위 테스트는 무엇입니까?파이썬의 단위 테스트는 무엇입니까?Apr 30, 2025 pm 02:05 PM

이 기사는 파이썬의 단위 테스트, 이점 및 효과적으로 작성하는 방법에 대해 설명합니다. 테스트를 위해 UnitTest 및 Pytest와 같은 도구를 강조 표시합니다.

Python의 액세스 지정자는 무엇입니까?Python의 액세스 지정자는 무엇입니까?Apr 30, 2025 pm 02:03 PM

기사는 Python의 액세스 지정자에 대해 논의합니다. Python은 명명 규칙을 사용하여 엄격한 시행보다는 클래스 멤버의 가시성을 나타냅니다.

파이썬의 __init __ () 란 무엇이며 자기 자신은 어떻게 역할을합니까?파이썬의 __init __ () 란 무엇이며 자기 자신은 어떻게 역할을합니까?Apr 30, 2025 pm 02:02 PM

기사는 Python의 \ _ \ _ init \ _ \ _ () 메소드와 객체 속성 초기화에서 자기의 역할에 대해 설명합니다. \ _ \ _ init \ _ \ _ ()에 대한 다른 클래스 방법 및 상속의 영향도 포함됩니다.

Python의 @ClassMethod, @StaticMethod 및 인스턴스 메소드의 차이점은 무엇입니까?Python의 @ClassMethod, @StaticMethod 및 인스턴스 메소드의 차이점은 무엇입니까?Apr 30, 2025 pm 02:01 PM

이 기사는 @classmethod, @staticMethod 및 Python의 인스턴스 방법의 차이점에 대해 설명하며 속성, 사용 사례 및 이점을 자세히 설명합니다. 필요한 기능과 DA를 기반으로 올바른 메소드 유형을 선택하는 방법을 설명합니다.

요소를 파이썬 어레이에 어떻게 추가합니까?요소를 파이썬 어레이에 어떻게 추가합니까?Apr 30, 2025 am 12:19 AM

inpython, youappendElementStoalistUsingTheAppend () 메소드 1) useappend () forsinglelements : my_list.append (4) .2) useextend () 또는 = formultiplementements : my_list.extend (other_list) 또는 my_list = [4,5,6] .3) useinsert () forspecificpositions : my_list.insert (1,5) .Bearware

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.