SQLAlchemy ORM - क्वेरी का उपयोग करना
SQLAlchemy ORM द्वारा उत्पन्न सभी सेलेक्ट स्टेटमेंट का निर्माण क्वेरी ऑब्जेक्ट द्वारा किया जाता है। यह एक सामान्य इंटरफ़ेस प्रदान करता है, इसलिए क्रमिक कॉल एक नई क्वेरी ऑब्जेक्ट लौटाता है, अतिरिक्त मानदंड और इसके साथ जुड़े विकल्पों के साथ पूर्व की एक प्रति।
क्वेरी ऑब्जेक्ट्स को प्रारंभ में सत्र की विधि () के रूप में निम्नानुसार उत्पन्न किया जाता है -
q = session.query(mapped class)
निम्नलिखित कथन भी ऊपर दिए गए कथन के समतुल्य है -
q = Query(mappedClass, session)
क्वेरी ऑब्जेक्ट में सभी () विधि है जो ऑब्जेक्ट की सूची के रूप में एक परिणाम देता है। यदि हम अपने ग्राहकों की मेज पर इसे निष्पादित करते हैं -
result = session.query(Customers).all()
यह कथन एसक्यूएल अभिव्यक्ति के लिए प्रभावी रूप से समकक्ष है -
SELECT customers.id
AS customers_id, customers.name
AS customers_name, customers.address
AS customers_address, customers.email
AS customers_email
FROM customers
परिणाम ऑब्जेक्ट को अंतर्निहित ग्राहक तालिका में सभी रिकॉर्ड प्राप्त करने के लिए नीचे दिए गए लूप का उपयोग करके पता लगाया जा सकता है। यहाँ ग्राहक तालिका में सभी रिकॉर्ड प्रदर्शित करने के लिए पूरा कोड है -
from sqlalchemy import Column, Integer, String
from sqlalchemy import create_engine
engine = create_engine('sqlite:///sales.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
class Customers(Base):
__tablename__ = 'customers'
id = Column(Integer, primary_key = True)
name = Column(String)
address = Column(String)
email = Column(String)
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()
result = session.query(Customers).all()
for row in result:
print ("Name: ",row.name, "Address:",row.address, "Email:",row.email)
पायथन कंसोल नीचे रिकॉर्ड की सूची दिखाता है -
Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
Name: Komal Pande Address: Koti, Hyderabad Email: [email protected]
Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]
Name: S.M.Krishna Address: Budhwar Peth, Pune Email: [email protected]
क्वेरी ऑब्जेक्ट में निम्न उपयोगी विधियाँ भी हैं -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | add_columns() यह परिणाम कॉलम की सूची में एक या अधिक कॉलम एक्सप्रेशन देता है। |
2 | add_entity() यह परिणामित स्तंभों की सूची में एक मैप की गई इकाई को जोड़ता है। |
3 | count() यह पंक्तियों की एक गिनती देता है यह क्वेरी वापस आ जाएगी। |
4 | delete() यह एक बल्क डिलीट क्वेरी करता है। डेटाबेस से इस क्वेरी द्वारा मेल की गई पंक्तियाँ हटा दी जाती हैं। |
5 | distinct() यह क्वेरी पर एक DISTINCT क्लॉज लागू करता है और नए परिणामी क्वेरी को वापस करता है। |
6 | filter() यह SQL अभिव्यक्तियों का उपयोग करते हुए, इस क्वेरी की एक प्रति के लिए दिए गए फ़िल्टरिंग मानदंड को लागू करता है। |
7 | first() यह इस क्वेरी का पहला परिणाम देता है या कोई भी अगर परिणाम में कोई पंक्ति नहीं है। |
8 | get() यह दिए गए प्राथमिक कुंजी पहचानकर्ता के आधार पर एक उदाहरण देता है जो मालिकाना सत्र के पहचान मानचित्र पर सीधे पहुंच प्रदान करता है। |
9 | group_by() यह क्वेरी के लिए एक या एक से अधिक GROUP BY मापदंड पर लागू होता है और नए परिणामी क्वेरी को वापस करता है |
10 | join() यह इस क्वेरी ऑब्जेक्ट की कसौटी के खिलाफ SQL JOIN बनाता है और नए परिणामी क्वेरी को लौटाते हुए उदारतापूर्वक लागू होता है। |
1 1 | one() यह ठीक एक परिणाम देता है या एक अपवाद बढ़ाता है। |
12 | order_by() यह क्वेरी के लिए एक या एक से अधिक आदेश मानदंड पर लागू होता है और नए परिणामी क्वेरी को वापस करता है। |
13 | update() यह एक बल्क अपडेट क्वेरी करता है और डेटाबेस में इस क्वेरी द्वारा मेल की गई पंक्तियों को अपडेट करता है। |