संबंधित वस्तुओं के साथ काम करना

इस अध्याय में, हम SQLAlchemy ORM में संबंधित वस्तुओं पर ध्यान केंद्रित करेंगे।

अब जब हम एक ग्राहक वस्तु बनाते हैं, तो एक खाली चालान संग्रह पायथन सूची के रूप में मौजूद होगा।

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)]

आइए हम इस ऑब्जेक्ट को सत्र ऑब्जेक्ट का उपयोग करते हुए डेटाबेस में निम्नानुसार करते हैं -

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 के टेबल व्यू में ग्राहकों की तालिका और चालान तालिका की सामग्री को देखते हैं -

आप नीचे दिए गए आदेश का उपयोग करके कंस्ट्रक्टर में चालान की मैप्ड विशेषता प्रदान करके ग्राहक वस्तु का निर्माण कर सकते हैं -

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()