관련 개체 작업

이 장에서는 SQLAlchemy ORM의 관련 개체에 중점을 둡니다.

이제 Customer 개체를 만들 때 빈 송장 컬렉션이 Python List 형식으로 표시됩니다.

c1 = Customer(name = "Gopal Krishna", address = "Bank Street Hydarebad", email = "[email protected]")

c1.invoices의 청구서 속성은 빈 목록이됩니다. 목록의 항목을 다음과 같이 할당 할 수 있습니다.

c1.invoices = [Invoice(invno = 10, amount = 15000), Invoice(invno = 14, amount = 3850)]

다음과 같이 Session 객체를 사용하여이 객체를 데이터베이스에 커밋합니다.

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()
session.add(c1)
session.commit()

이것은 자동으로 고객 및 송장 테이블에 대한 INSERT 쿼리를 생성합니다-

INSERT INTO customers (name, address, email) VALUES (?, ?, ?) 
('Gopal Krishna', 'Bank Street Hydarebad', '[email protected]')
INSERT INTO invoices (custid, invno, amount) VALUES (?, ?, ?)
(2, 10, 15000)
INSERT INTO invoices (custid, invno, amount) VALUES (?, ?, ?)
(2, 14, 3850)

이제 SQLiteStudio의 테이블보기에서 고객 테이블과 송장 테이블의 내용을 살펴 보겠습니다.

아래 명령을 사용하여 생성자 자체에서 송장의 매핑 된 속성을 제공하여 Customer 객체를 생성 할 수 있습니다.

c2 = [
   Customer(
      name = "Govind Pant", 
      address = "Gulmandi Aurangabad",
      email = "[email protected]",
      invoices = [Invoice(invno = 3, amount = 10000), 
      Invoice(invno = 4, amount = 5000)]
   )
]

또는 아래와 같이 세션 객체의 add_all () 함수를 사용하여 추가 할 객체 목록-

rows = [
   Customer(
      name = "Govind Kala", 
      address = "Gulmandi Aurangabad", 
      email = "[email protected]", 
      invoices = [Invoice(invno = 7, amount = 12000), Invoice(invno = 8, amount = 18500)]),

   Customer(
      name = "Abdul Rahman", 
      address = "Rohtak", 
      email = "[email protected]",
      invoices = [Invoice(invno = 9, amount = 15000), 
      Invoice(invno = 11, amount = 6000)
   ])
]

session.add_all(rows)
session.commit()