백엔드 개발 파이썬 튜토리얼 Flask-SQLAlchemy 및 Alembic: Python 웹 애플리케이션에서 데이터베이스 마이그레이션 모범 사례(2부)

Flask-SQLAlchemy 및 Alembic: Python 웹 애플리케이션에서 데이터베이스 마이그레이션 모범 사례(2부)

Jun 17, 2023 pm 08:34 PM
flask sqlalchemy 데이터베이스 마이그레이션

Flask-SQLAlchemy 및 Alembic: Python 웹 애플리케이션에서 데이터베이스 마이그레이션을 위한 모범 사례(2부)

이전 기사에서는 Flask-SQLAlchemy와 Alembic이 함께 작동하는 방식에 대해 논의했습니다. 이 기사에서는 일부 기본 데이터 모델에서 열을 추가 및 제거하는 방법과 일부 열의 유형 또는 제약 조건을 수정하는 방법을 주로 소개합니다. 이러한 변경은 실제 프로젝트 개발 중에 매우 일반적입니다.

열 추가 및 삭제

데이터베이스 마이그레이션을 위해 Flask-SQLAlchemy 및 Alembic을 사용할 때 테이블 열을 추가하고 제거하는 것은 매우 일반적입니다. 이 프로세스를 보여주기 위해 다음 예제 Person 모델에 몇 가지 새로운 열을 추가하겠습니다.

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

class Person(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(255), nullable=False)
    age = db.Column(db.Integer)

    def __repr__(self):
        return '<Person %r>' % self.name
로그인 후 복사

두 개의 새 열을 추가한다고 가정해 보겠습니다. 하나는 생년월일(birthdate)이고 다른 하나는 결혼 여부(is_married)를 나타내는 부울 열입니다. 다음 명령을 사용하여 마이그레이션 스크립트를 생성할 수 있습니다.

$ alembic revision -m "add birthdate, is_married columns to person"
로그인 후 복사

다음으로 생성된 .py 마이그레이션 스크립트 파일을 수정하여 새 열을 추가해야 합니다. 업그레이드() 함수에서 add_column()을 사용할 수 있습니다.

from alembic import op
import sqlalchemy as sa

def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.add_column('person', sa.Column('birthdate', sa.Date(), nullable=True))
    op.add_column('person', sa.Column('is_married', sa.Boolean(), nullable=True))
    # ### end Alembic commands ###
로그인 후 복사

열을 삭제하려면 해당 소멸자 Degrad()에서 drop_column() 함수를 사용하여 데이터베이스 모델에서 열을 삭제할 수 있습니다.

def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_column('person', 'birthdate')
    op.drop_column('person', 'is_married')
    # ### end Alembic commands ###
로그인 후 복사

이 마이그레이션 스크립트의 전체 샘플 코드는 아래에서 찾을 수 있습니다.

"""add birthdate, is_married columns to person"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = 'eab2c4f1c9fb'
down_revision = '7cfae59c2402'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.add_column('person', sa.Column('birthdate', sa.Date(), nullable=True))
    op.add_column('person', sa.Column('is_married', sa.Boolean(), nullable=True))
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_column('person', 'birthdate')
    op.drop_column('person', 'is_married')
    # ### end Alembic commands ###
로그인 후 복사

열 유형 변경 및 제약 조건 수정

많은 경우 열 유형 및 제약 조건을 수정해야 합니다. Person 모델의 age 열 유형을 INTEGER에서 SMALLINT로 변경한다고 가정합니다. 이를 달성하기 위해 생성된 .py 마이그레이션 스크립트 파일에서 alter_column() 함수를 사용할 수 있습니다.

def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.alter_column('person', 'age', existing_type=sa.Integer(),
               type_=sa.SmallInteger(), nullable=True)
    # ### end Alembic commands ###
로그인 후 복사

열에 대한 제약 조건을 수정할 수도 있습니다. Person 모델을 조사해 보면 모델에 고유 값 제약 조건이 없다는 것을 알 수 있습니다. 다음 코드를 사용하여 이름 및 생년월일 열에 고유 값 제약 조건을 추가할 수 있습니다.

from alembic import op
import sqlalchemy as sa

def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_unique_constraint(op.f('uq_person_name'), 'person', ['name'])
    op.create_unique_constraint(op.f('uq_person_birthdate'), 'person', ['birthdate'])
    # ### end Alembic commands ###
로그인 후 복사

나중에 고유 값 제약 조건을 취소해야 하는 경우 drop_constraint() 함수를 사용할 수 있습니다. 예:

def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_constraint(op.f('uq_person_name'), 'person', type_='unique')
    op.drop_constraint(op.f('uq_person_birthdate'), 'person', type_='unique')
    # ### end Alembic commands ###
로그인 후 복사

이 문서에서는 열 추가 및 제거, 열 제약 조건 변경, 열 데이터 유형 변경 등 몇 가지 일반적인 유형의 데이터베이스 스키마 변경을 다룹니다. Flask-SQLAlchemy 및 Alembic을 사용한 데이터베이스 마이그레이션 모범 사례를 보여줍니다. 이를 통해 데이터베이스 스키마를 보다 효율적으로 관리하고 팀 환경에서 마이그레이션 파일을 보다 쉽게 ​​공유할 수 있습니다.

참조 링크:

  • Flask-SQLAlchemy - https://flask-sqlalchemy.palletsprojects.com/
  • Alembic - https://alembic.sqlalchemy.org/en/latest/

위 내용은 Flask-SQLAlchemy 및 Alembic: Python 웹 애플리케이션에서 데이터베이스 마이그레이션 모범 사례(2부)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

React와 Flask를 사용하여 간단하고 사용하기 쉬운 웹 애플리케이션을 구축하는 방법 React와 Flask를 사용하여 간단하고 사용하기 쉬운 웹 애플리케이션을 구축하는 방법 Sep 27, 2023 am 11:09 AM

React와 Flask를 사용하여 간단하고 사용하기 쉬운 웹 애플리케이션을 구축하는 방법 소개: 인터넷의 발전과 함께 웹 애플리케이션의 요구 사항은 점점 더 다양해지고 복잡해지고 있습니다. 사용 편의성과 성능에 대한 사용자 요구 사항을 충족하기 위해 최신 기술 스택을 사용하여 네트워크 애플리케이션을 구축하는 것이 점점 더 중요해지고 있습니다. React와 Flask는 프런트엔드 및 백엔드 개발을 위한 매우 인기 있는 프레임워크이며, 함께 잘 작동하여 간단하고 사용하기 쉬운 웹 애플리케이션을 구축합니다. 이 글에서는 React와 Flask를 활용하는 방법을 자세히 설명합니다.

Django와 Flask: Python 웹 프레임워크 비교 분석 Django와 Flask: Python 웹 프레임워크 비교 분석 Jan 19, 2024 am 08:36 AM

Django와 Flask는 모두 Python 웹 프레임워크의 리더이며 둘 다 고유한 장점과 적용 가능한 시나리오를 가지고 있습니다. 이 기사에서는 이 두 프레임워크를 비교 분석하고 구체적인 코드 예제를 제공합니다. 개발 소개 Django는 모든 기능을 갖춘 웹 프레임워크이며, 주요 목적은 복잡한 웹 애플리케이션을 신속하게 개발하는 것입니다. Django는 ORM(Object Relational Mapping), 양식, 인증, 관리 백엔드 등과 같은 다양한 내장 기능을 제공합니다. 이러한 기능을 통해 Django는 대규모 처리를 수행할 수 있습니다.

처음부터 시작하여 Flask를 설치하고 개인 블로그를 빠르게 구축하는 방법을 단계별로 안내합니다. 처음부터 시작하여 Flask를 설치하고 개인 블로그를 빠르게 구축하는 방법을 단계별로 안내합니다. Feb 19, 2024 pm 04:01 PM

Flask를 설치하는 방법과 개인 블로그를 빠르게 구축하는 방법을 처음부터 차근차근 가르쳐드리겠습니다. 글쓰기를 좋아하는 사람으로서 개인 블로그를 갖는 것은 매우 중요합니다. 경량 Python 웹 프레임워크인 Flask를 사용하면 간단하고 완전한 기능을 갖춘 개인 블로그를 빠르게 구축할 수 있습니다. 이 기사에서는 처음부터 시작하여 Flask를 설치하고 개인 블로그를 빠르게 구축하는 방법을 단계별로 가르쳐 드리겠습니다. 1단계: Python 및 pip 설치 시작하기 전에 먼저 Python 및 pi를 설치해야 합니다.

Flask 프레임워크 설치 가이드: Flask를 올바르게 설치하는 데 도움이 되는 자세한 단계 Flask 프레임워크 설치 가이드: Flask를 올바르게 설치하는 데 도움이 되는 자세한 단계 Feb 18, 2024 pm 10:51 PM

Flask 프레임워크 설치 튜토리얼: Flask 프레임워크를 올바르게 설치하는 방법을 단계별로 설명합니다. 특정 코드 예제가 필요합니다. 소개: Flask는 간단하고 유연한 Python 웹 개발 프레임워크입니다. 배우기 쉽고 사용하기 쉬우며 강력한 기능이 가득합니다. 이 문서에서는 Flask 프레임워크를 올바르게 설치하는 방법을 단계별로 안내하고 참조할 수 있는 자세한 코드 예제를 제공합니다. 1단계: Python 설치 Flask 프레임워크를 설치하기 전에 먼저 Python이 컴퓨터에 설치되어 있는지 확인해야 합니다. P부터 시작할 수 있습니다.

Flask와 Intellij IDEA 통합: Python 웹 애플리케이션 개발 팁(2부) Flask와 Intellij IDEA 통합: Python 웹 애플리케이션 개발 팁(2부) Jun 17, 2023 pm 01:58 PM

첫 번째 부분에서는 기본적인 Flask와 Intellij IDEA 통합, 프로젝트 및 가상 환경 설정, 종속성 설치 등에 대해 소개합니다. 다음으로 우리는 더 효율적인 작업 환경을 구축하기 위해 더 많은 Python 웹 애플리케이션 개발 팁을 계속 탐색할 것입니다. FlaskBlueprintsFlaskBlueprints를 사용하면 더 쉽게 관리하고 유지 관리할 수 있도록 애플리케이션 코드를 구성할 수 있습니다. Blueprint는 패키지를 구성하는 Python 모듈입니다.

Flask 애플리케이션 배포를 위한 Gunicorn과 uWSGI의 성능 비교 Flask 애플리케이션 배포를 위한 Gunicorn과 uWSGI의 성능 비교 Jan 17, 2024 am 08:52 AM

Flask 애플리케이션 배포: Gunicorn과 suWSGI 비교 소개: 경량 Python 웹 프레임워크인 Flask는 많은 개발자들에게 사랑을 받고 있습니다. Flask 애플리케이션을 프로덕션 환경에 배포할 때 적절한 SGI(서버 게이트웨이 인터페이스)를 선택하는 것은 중요한 결정입니다. Gunicorn과 uWSGI는 두 가지 일반적인 SGI 서버입니다. 이 기사에서는 이에 대해 자세히 설명합니다.

Flask vs FastAPI: 효율적인 웹 API 개발을 위한 최선의 선택 Flask vs FastAPI: 효율적인 웹 API 개발을 위한 최선의 선택 Sep 27, 2023 pm 09:01 PM

FlaskvsFastAPI: 효율적인 WebAPI 개발을 위한 최선의 선택 소개: 현대 소프트웨어 개발에서 WebAPI는 없어서는 안 될 부분이 되었습니다. 이는 서로 다른 애플리케이션 간의 통신과 상호 운용성을 가능하게 하는 데이터와 서비스를 제공합니다. WebAPI 개발을 위한 프레임워크를 선택할 때 많은 관심을 받은 두 가지 선택은 Flask와 FastAPI입니다. 두 프레임워크 모두 매우 인기가 높으며 각각 고유한 장점이 있습니다. 이번 글에서는 Fl에 대해 알아보겠습니다.

Flask 및 D3.js를 사용하여 대화형 데이터 시각화 웹 애플리케이션 구축 Flask 및 D3.js를 사용하여 대화형 데이터 시각화 웹 애플리케이션 구축 Jun 17, 2023 pm 09:00 PM

최근 몇 년 동안 데이터 분석과 데이터 시각화는 많은 산업과 분야에서 필수적인 기술이 되었습니다. 많은 양의 데이터를 사용자 앞에 제시하고 시각화를 통해 사용자가 데이터의 의미와 특성을 이해할 수 있도록 하는 것은 데이터 분석가와 연구자에게 매우 중요합니다. 이러한 요구를 충족하기 위해 D3.js를 사용하여 웹 애플리케이션에서 대화형 데이터 시각화를 구축하는 것이 추세가 되었습니다. 이 기사에서는 Flask 및 D3.js를 사용하여 웹용 대화형 데이터 시각화를 구축하는 방법을 다룹니다.

See all articles