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