찾다
백엔드 개발파이썬 튜토리얼Python에서 SQLAlchemy를 사용하여 관계 만들기

Creating relationships using SQLAlchemy in Python

SQLAlchemy는 SQL 테이블을 생성하려고 할 때 Python에 필요한 많은 작업에 도움을 줄 수 있으며 이러한 작업 중 하나는 관계를 생성하는 것입니다.

SQLAlchemy를 사용하면 SQL만 사용하는 것보다 훨씬 쉽게 관계를 생성할 수 있습니다. 구문을 더 쉽게 따르고 단계를 줄여 프로세스를 간소화합니다.

SQLAlchemy를 Python으로 가져오며 모든 단축 구문을 사용할 수 있습니다.

 from flask_sqlalchemy import SQLAlchemy

관계를 만들려면 테이블을 만드는 것부터 시작해야 합니다. SQLAlchemy에서는 구문을 다음과 같이 단축하여 이 작업도 쉽게 수행할 수 있습니다.

class Owner(db.Model, SerializerMixin):
    __tablename__ = "owners"
    id = db.Column(db.Integer, primary_key=True)

이렇게 하면 기본 키인 ID를 가진 소유자 테이블이 생성됩니다. 소유자에 대한 열 속성을 생성하는 데 다른 코드를 사용할 수 있습니다. 이는 관계를 연결하는 데 도움이 될 것입니다. 열이 생성되면 나중에 생성할 Dog 테이블 연결 작업을 수행할 수 있습니다. 관계 코드는 다음과 같습니다.

dogs = db.relationship('Dog', back_populates='owner')

이것은 개와 주인을 연결하는 것으로, 주인은 여러 마리의 개를 가질 수 있지만 뒤에서 볼 때 개는 주인이 한 명인 경우가 단수입니다.

그런 다음 개 클래스와 테이블을 만들 수 있습니다. 여러 개의 열 속성을 가질 수 있습니다. 관계에서 중요한 점은 외래 키가 있는 소유자 ID가 있어야 한다는 것입니다. 이는 SQLAlchemy에서 다음과 같이 작성됩니다.

owner_id = db.Column(db.Integer, db.ForeignKey('owners.id')) 

그러면 주인처럼 관계를 맺게 됩니다. 이것은 반대이며 아래 코드를 사용하여 개를 소유자와 연결합니다.

owner = db.relationship('Owner', back_populates= 'dogs')

여기서 back은 개로 채워지는 대신 개입니다. 소유자는 여러 개를 가질 수 있지만 개는 소유자가 한 명이므로 이전 코드는 소유자였습니다.

이제 두 테이블은 관계를 갖게 됩니다. 앞서 언급했듯이 이는 법적으로 필요한 코드의 양을 줄이고 구문을 SQL로 작성하는 것보다 간단하게 만듭니다.

연관 프록시를 추가하고 무한 루프에 도움이 되는 직렬화 규칙을 생성하기 위해 더 많은 코드를 추가할 수 있지만 위의 방법은 SQLAlchemy를 사용하지 않았을 때보다 훨씬 빠르게 초기 관계를 생성합니다.

위 내용은 Python에서 SQLAlchemy를 사용하여 관계 만들기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

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

2 시간의 파이썬 계획 : 현실적인 접근2 시간의 파이썬 계획 : 현실적인 접근Apr 11, 2025 am 12:04 AM

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

파이썬 : 기본 응용 프로그램 탐색파이썬 : 기본 응용 프로그램 탐색Apr 10, 2025 am 09:41 AM

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

2 시간 안에 얼마나 많은 파이썬을 배울 수 있습니까?2 시간 안에 얼마나 많은 파이썬을 배울 수 있습니까?Apr 09, 2025 pm 04:33 PM

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

10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법?10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법?Apr 02, 2025 am 07:18 AM

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까?중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까?Apr 02, 2025 am 07:15 AM

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

Python 3.6에 피클 파일을로드 할 때 '__builtin__'모듈을 찾을 수없는 경우 어떻게해야합니까?Python 3.6에 피클 파일을로드 할 때 '__builtin__'모듈을 찾을 수없는 경우 어떻게해야합니까?Apr 02, 2025 am 07:12 AM

Python 3.6에 피클 파일로드 3.6 환경 보고서 오류 : modulenotfounderror : nomodulename ...

경치 좋은 스팟 코멘트 분석에서 Jieba Word 세분화의 정확성을 향상시키는 방법은 무엇입니까?경치 좋은 스팟 코멘트 분석에서 Jieba Word 세분화의 정확성을 향상시키는 방법은 무엇입니까?Apr 02, 2025 am 07:09 AM

경치 좋은 스팟 댓글 분석에서 Jieba Word 세분화 문제를 해결하는 방법은 무엇입니까? 경치가 좋은 스팟 댓글 및 분석을 수행 할 때 종종 Jieba Word 세분화 도구를 사용하여 텍스트를 처리합니다 ...

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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

메모장++7.3.1

메모장++7.3.1

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