SQLAlchemy ORM-관계 구축

이 세션에서는 데이터베이스에 이미있는 테이블과 관련된 다른 테이블을 만드는 방법에 대해 설명합니다. 고객 테이블에는 고객의 마스터 데이터가 포함됩니다. 이제 고객에게 속한 모든 송장을 포함 할 수있는 송장 테이블을 만들어야합니다. 이것은 일대 다 관계의 경우입니다.

선언적을 사용하여 매핑 된 클래스 인 송장과 함께이 테이블을 정의합니다.

from sqlalchemy import create_engine, ForeignKey, Column, Integer, String
engine = create_engine('sqlite:///sales.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
from sqlalchemy.orm import relationship

class Customer(Base):
   __tablename__ = 'customers'

   id = Column(Integer, primary_key = True)
   name = Column(String)
   address = Column(String)
   email = Column(String)

class Invoice(Base):
   __tablename__ = 'invoices'
   
   id = Column(Integer, primary_key = True)
   custid = Column(Integer, ForeignKey('customers.id'))
   invno = Column(Integer)
   amount = Column(Integer)
   customer = relationship("Customer", back_populates = "invoices")

Customer.invoices = relationship("Invoice", order_by = Invoice.id, back_populates = "customer")
Base.metadata.create_all(engine)

다음과 같이 SQLite 엔진에 CREATE TABLE 쿼리를 보냅니다.

CREATE TABLE invoices (
   id INTEGER NOT NULL,
   custid INTEGER,
   invno INTEGER,
   amount INTEGER,
   PRIMARY KEY (id),
   FOREIGN KEY(custid) REFERENCES customers (id)
)

SQLiteStudio 도구를 사용하여 sales.db에 새 테이블이 생성되었는지 확인할 수 있습니다.

Invoices 클래스는 custid 속성에 ForeignKey 구성을 적용합니다. 이 지시문은이 열의 값이 customers 테이블의 id 열에있는 값으로 제한되어야 함을 나타냅니다. 이것은 관계형 데이터베이스의 핵심 기능이며 연결되지 않은 테이블 컬렉션을 풍부한 중첩 관계를 갖도록 변환하는 "접착제"입니다.

relationship ()이라고하는 두 번째 지시문은 ORM에게 Invoice.customer 속성을 사용하여 Invoice 클래스가 Customer 클래스에 연결되어야 함을 알려줍니다. relationship ()은 두 테이블 간의 외래 키 관계를 사용하여이 연결의 특성을 결정하고 다대 일인지 확인합니다.

추가 relationship () 지시문은 Customer.invoices 속성 아래의 Customer 매핑 클래스에 배치됩니다. 매개 변수 relationship.back_populates는 보완 속성 이름을 참조하도록 지정되므로 각 relationship ()은 반대로 표현 된 것과 동일한 관계에 대해 지능적인 결정을 내릴 수 있습니다. 한쪽에서 Invoices.customer는 Invoices 인스턴스를 참조하고 다른 쪽에서 Customer.invoices는 Customers 인스턴스 목록을 참조합니다.

관계 함수는 SQLAlchemy ORM 패키지의 Relationship API의 일부입니다. 두 개의 매핑 된 클래스 간의 관계를 제공합니다. 이것은 상위-하위 또는 연관 테이블 관계에 해당합니다.

다음은 발견 된 기본 관계 패턴입니다-

일대 다

일대 다 관계는 자식 테이블의 외래 키를 사용하여 부모를 나타냅니다. 그런 다음 child가 나타내는 항목 모음을 참조하여 parent에 관계 ()가 지정됩니다. relationship.back_populates 매개 변수는 일대 다에서 양방향 관계를 설정하는 데 사용됩니다. 여기서 "역"쪽은 다 대일입니다.

다 대일

반면 다 대일 관계는 상위 테이블에 외래 키를 배치하여 하위를 참조합니다. relationship ()은 새로운 스칼라 보유 속성이 생성되는 부모에서 선언됩니다. 여기서 다시 relationship.back_populates 매개 변수가 양방향 동작에 사용됩니다.

1-1

일대일 관계는 본질적으로 양방향 관계입니다. uselist 플래그는 관계의 "다"쪽에서 컬렉션 대신 스칼라 속성의 배치를 나타냅니다. 일대 다를 일대일 관계 유형으로 변환하려면 uselist 매개 변수를 false로 설정하십시오.

다 대다

다 대다 관계는 외래 키로 속성을 정의하여 두 클래스와 관련된 연관 테이블을 추가하여 설정됩니다. relationship ()에 대한 보조 인수로 표시됩니다. 일반적으로 Table은 선언적 기본 클래스와 연결된 MetaData 개체를 사용하므로 ForeignKey 지시문은 연결할 원격 테이블을 찾을 수 있습니다. 각 relationship ()에 대한 relationship.back_populates 매개 변수는 양방향 관계를 설정합니다. 관계의 양쪽에는 컬렉션이 있습니다.