SQLAlchemy ORM - लोड हो रहा है
उत्सुक भार प्रश्नों की संख्या को कम करता है। SQLAlchemy क्वेरी विकल्प के माध्यम से आह्वान किए गए उत्सुक लोडिंग फ़ंक्शन प्रदान करता है जो क्वेरी को अतिरिक्त निर्देश देते हैं। ये विकल्प निर्धारित करते हैं कि Query.options () विधि के माध्यम से विभिन्न विशेषताओं को कैसे लोड किया जाए।
उपशम भार
हम चाहते हैं कि Customer.invoices को उत्सुकता से लोड करना चाहिए। Orm.subqueryload () विकल्प दूसरा सेलेक्ट स्टेटमेंट देता है जो पूरी तरह से लोड किए गए परिणामों से जुड़े संग्रह को पूरी तरह से लोड करता है। "सबक्वेरी" नाम का चयन सेलेक्ट स्टेटमेंट को सीधे क्वेरी के माध्यम से निर्माण करने के लिए किया जाता है और संबंधित तालिका के खिलाफ एक चयन में एक सबक्वेरी के रूप में एम्बेडेड होता है।
from sqlalchemy.orm import subqueryload
c1 = session.query(Customer).options(subqueryload(Customer.invoices)).filter_by(name = 'Govind Pant').one()
इसके परिणामस्वरूप निम्न दो SQL अभिव्यक्तियाँ होती हैं -
SELECT customers.id
AS customers_id, customers.name
AS customers_name, customers.address
AS customers_address, customers.email
AS customers_email
FROM customers
WHERE customers.name = ?
('Govind Pant',)
SELECT invoices.id
AS invoices_id, invoices.custid
AS invoices_custid, invoices.invno
AS invoices_invno, invoices.amount
AS invoices_amount, anon_1.customers_id
AS anon_1_customers_id
FROM (
SELECT customers.id
AS customers_id
FROM customers
WHERE customers.name = ?)
AS anon_1
JOIN invoices
ON anon_1.customers_id = invoices.custid
ORDER BY anon_1.customers_id, invoices.id 2018-06-25 18:24:47,479
INFO sqlalchemy.engine.base.Engine ('Govind Pant',)
दो तालिकाओं से डेटा तक पहुंचने के लिए, हम नीचे दिए गए प्रोग्राम का उपयोग कर सकते हैं -
print (c1.name, c1.address, c1.email)
for x in c1.invoices:
print ("Invoice no : {}, Amount : {}".format(x.invno, x.amount))
उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार है -
Govind Pant Gulmandi Aurangabad [email protected]
Invoice no : 3, Amount : 10000
Invoice no : 4, Amount : 5000
लोड में शामिल हुए
अन्य फ़ंक्शन को orm.joinedload () कहा जाता है। यह एक LEFT OUTER JOIN का उत्सर्जन करता है। लीड ऑब्जेक्ट के साथ-साथ संबंधित ऑब्जेक्ट या संग्रह को एक चरण में लोड किया जाता है।
from sqlalchemy.orm import joinedload
c1 = session.query(Customer).options(joinedload(Customer.invoices)).filter_by(name='Govind Pant').one()
यह निम्न के रूप में समान आउटपुट देते हुए निम्नलिखित अभिव्यक्ति का उत्सर्जन करता है -
SELECT customers.id
AS customers_id, customers.name
AS customers_name, customers.address
AS customers_address, customers.email
AS customers_email, invoices_1.id
AS invoices_1_id, invoices_1.custid
AS invoices_1_custid, invoices_1.invno
AS invoices_1_invno, invoices_1.amount
AS invoices_1_amount
FROM customers
LEFT OUTER JOIN invoices
AS invoices_1
ON customers.id = invoices_1.custid
WHERE customers.name = ? ORDER BY invoices_1.id
('Govind Pant',)
OUTER JOIN का परिणाम दो पंक्तियों में है, लेकिन यह ग्राहक को एक उदाहरण देता है। इसका कारण यह है कि क्वेरी एक "विशिष्ट" रणनीति लागू करती है, वस्तु पहचान के आधार पर, लौटी संस्थाओं को। शामिल किए गए उत्सुक लोडिंग को क्वेरी परिणामों को प्रभावित किए बिना लागू किया जा सकता है।
सब-लोड () एक साथ लोड करने के लिए संबंधित संग्रह लोड करने के लिए अधिक उपयुक्त है () कई-से-एक संबंध के लिए बेहतर अनुकूल है।