SQLAlchemy ORM - टेक्स्ट एसक्यूएल

इससे पहले, पाठ () फ़ंक्शन का उपयोग करते हुए शाब्दिक SQL को SQLAlchemy की मूल अभिव्यक्ति भाषा के परिप्रेक्ष्य से समझाया गया है। अब हम ORM दृष्टिकोण से इसकी चर्चा करेंगे।

पाठ () निर्माण के साथ उनके उपयोग को निर्दिष्ट करके क्वेरी के ऑब्जेक्ट के साथ शाब्दिक तार का उपयोग लचीले ढंग से किया जा सकता है। अधिकांश लागू विधियाँ इसे स्वीकार करती हैं। उदाहरण के लिए, फ़िल्टर () और order_by ()।

नीचे दिए गए उदाहरण में, फ़िल्टर () विधि स्ट्रिंग "आईडी <3" का अनुवाद WHERE आईडी <3 में करती है

from sqlalchemy import text
for cust in session.query(Customers).filter(text("id<3")):
   print(cust.name)

उत्पन्न कच्चे 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 id<3

ग्राहक तालिका में हमारे नमूना डेटा से, दो पंक्तियों का चयन किया जाएगा और नाम कॉलम को निम्नानुसार मुद्रित किया जाएगा -

Ravi Kumar
Komal Pande

स्ट्रिंग-आधारित SQL के साथ बाइंड मापदंडों को निर्दिष्ट करने के लिए, एक कोलन का उपयोग करें, और मानों को निर्दिष्ट करने के लिए, params () विधि का उपयोग करें।

cust = session.query(Customers).filter(text("id = :value")).params(value = 1).one()

पायथन कंसोल पर प्रदर्शित प्रभावी एसक्यूएल नीचे दिया जाएगा -

SELECT customers.id 
AS customers_id, customers.name 
AS customers_name, customers.address 
AS customers_address, customers.email 
AS customers_email
FROM customers
WHERE id = ?

पूरी तरह से स्ट्रिंग-आधारित कथन का उपयोग करने के लिए, एक पाठ () एक पूर्ण कथन का प्रतिनिधित्व करने वाला निर्माण from_statement () में पारित किया जा सकता है।

session.query(Customers).from_statement(text("SELECT * FROM customers")).all()

उपरोक्त कोड का परिणाम नीचे दिए गए अनुसार एक बुनियादी चयन कथन होगा -

SELECT * FROM customers

जाहिर है, ग्राहकों की तालिका में सभी रिकॉर्ड का चयन किया जाएगा।

पाठ () निर्माण हमें इसकी शाब्दिक एसक्यूएल को कोर या ओआरएम-मैप्ड कॉलम अभिव्यक्तियों से जोड़ने की अनुमति देता है। हम स्तंभ अभिव्यक्ति को TextClause.columns () विधि के रूप में स्थितीय तर्क देकर इसे प्राप्त कर सकते हैं।

stmt = text("SELECT name, id, name, address, email FROM customers")
stmt = stmt.columns(Customers.id, Customers.name)
session.query(Customers.id, Customers.name).from_statement(stmt).all()

सभी पंक्तियों के आईडी और नाम कॉलम को चुना जाएगा भले ही SQLite इंजन उपरोक्त कोड द्वारा उत्पन्न अभिव्यक्ति का पालन करता है पाठ () विधि में सभी कॉलम दिखाता है -

SELECT name, id, name, address, email FROM customers