SQLAlchemy - त्वरित गाइड

SQLAlchemy एक लोकप्रिय SQL टूलकिट और है Object Relational Mapper। इसमें लिखा हैPythonऔर एक एप्लिकेशन डेवलपर को SQL की पूरी शक्ति और लचीलापन देता है। यह एकopen source तथा cross-platform software एमआईटी लाइसेंस के तहत जारी किया गया।

SQLAlchemy अपने ऑब्जेक्ट-रिलेशनल मैपर (ORM) के लिए प्रसिद्ध है, जिसके उपयोग से, कक्षाओं को डेटाबेस में मैप किया जा सकता है, जिससे ऑब्जेक्ट मॉडल और डेटाबेस स्कीमा को शुरू से साफ-सुथरे तरीके से विकसित करने की अनुमति मिलती है।

जैसे-जैसे SQL डेटाबेस का आकार और प्रदर्शन मायने रखने लगता है, वे वस्तु संग्रह की तरह कम व्यवहार करते हैं। दूसरी ओर, जैसा कि वस्तु संग्रह में अमूर्तता मायने रखती है, वे तालिकाओं और पंक्तियों की तरह कम व्यवहार करते हैं। SQLAlchemy का लक्ष्य इन दोनों सिद्धांतों को समायोजित करना है।

इस कारण से, इसने अपनाया है data mapper pattern (like Hibernate) rather than the active record pattern used by a number of other ORMs। डेटाबेस और SQL को SQLAlchemy का उपयोग करके एक अलग परिप्रेक्ष्य में देखा जाएगा।

माइकल बेयर SQLAlchemy के मूल लेखक हैं। इसका प्रारंभिक संस्करण फरवरी 2006 में जारी किया गया था। नवीनतम संस्करण 1.2.7 के रूप में गिना जाता है, हाल ही में अप्रैल 2018 में जारी किया गया।

ORM क्या है?

ORM (ऑब्जेक्ट रिलेशनल मैपिंग) ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग भाषाओं में असंगत प्रकार के सिस्टम के बीच डेटा परिवर्तित करने के लिए एक प्रोग्रामिंग तकनीक है। आमतौर पर, ऑब्जेक्ट ऑब्जेक्ट ओरिएंटेड (OO) भाषा में पाइथन जैसी भाषा का उपयोग किया जाता है जिसमें गैर-स्केलर प्रकार होते हैं। इन्हें पूर्णांक और स्ट्रिंग्स जैसे आदिम प्रकार के रूप में व्यक्त नहीं किया जा सकता है। इसलिए, OO प्रोग्रामर को बैकएंड डेटाबेस के साथ सहभागिता करने के लिए स्केलर डेटा में ऑब्जेक्ट्स को कनवर्ट करना पड़ता है। हालाँकि, अधिकांश डेटाबेस उत्पादों जैसे कि Oracle, MySQL आदि में डेटा प्रकार प्राथमिक हैं।

ORM सिस्टम में, प्रत्येक वर्ग अंतर्निहित डेटाबेस में एक टेबल पर मैप करता है। अपने आप को थकाऊ डेटाबेस इंटरफेसिंग कोड लिखने के बजाय, एक ORM आपके लिए इन मुद्दों का ध्यान रखता है, जबकि आप सिस्टम के लॉजिक्स की प्रोग्रामिंग पर ध्यान केंद्रित कर सकते हैं।

SQLAlchemy - पर्यावरण सेटअप

आइए SQLAlchemy का उपयोग करने के लिए आवश्यक पर्यावरण सेटअप पर चर्चा करें।

SQLAlchemy को स्थापित करने के लिए 2.7 से अधिक पायथन का कोई भी संस्करण आवश्यक है। पायथन पैकेज मैनेजर का उपयोग करके स्थापित करने का सबसे आसान तरीका है,pip। इस उपयोगिता को पायथन के मानक वितरण के साथ बांधा गया है।

pip install sqlalchemy

उपरोक्त कमांड का उपयोग करके, हम डाउनलोड कर सकते हैं latest released versionpython.org से SQLAlchemy और इसे अपने सिस्टम में संस्थापित करें।

पायथन के एनाकोंडा वितरण के मामले में, SQLAlchemy से स्थापित किया जा सकता है conda terminal नीचे दिए गए आदेश का उपयोग कर -

conda install -c anaconda sqlalchemy

स्रोत कोड के नीचे से SQLAlchemy स्थापित करना भी संभव है -

python setup.py install

SQLAlchemy को एक विशेष डेटाबेस के लिए निर्मित DBAPI कार्यान्वयन के साथ संचालित करने के लिए डिज़ाइन किया गया है। यह विभिन्न प्रकार के DBAPI कार्यान्वयन और डेटाबेस के साथ संवाद करने के लिए बोली प्रणाली का उपयोग करता है। सभी बोलियों के लिए आवश्यक है कि एक उपयुक्त DBAPI ड्राइवर स्थापित हो।

निम्नलिखित बोलियाँ शामिल हैं -

  • Firebird
  • Microsoft SQL सर्वर
  • MySQL
  • Oracle
  • PostgreSQL
  • SQLite
  • Sybase

यह जाँचने के लिए कि SQLAlchemy ठीक से स्थापित है और इसका संस्करण जानने के लिए, पायथन प्रॉम्प्ट में निम्न कमांड दर्ज करें -

>>> import sqlalchemy
>>>sqlalchemy.__version__
'1.2.7'

SQLAlchemy कोर शामिल हैं SQL rendering engine, DBAPI integration, transaction integration, तथा schema description services। SQLAlchemy कोर SQL अभिव्यक्ति भाषा है कि प्रदान करता है का उपयोग करता हैschema-centric usage प्रतिमान जबकि SQLAlchemy ORM एक है domain-centric mode of usage

SQL एक्सप्रेशन लैंग्वेज पायथन कंस्ट्रक्शंस का उपयोग करके रिलेशनल डेटाबेस स्ट्रक्चर्स और एक्सप्रेशन को दर्शाने की एक प्रणाली प्रस्तुत करता है। यह बिना राय के सीधे संबंधित डेटाबेस के आदिम निर्माणों का प्रतिनिधित्व करने की एक प्रणाली प्रस्तुत करता है, जो ORM के विपरीत है जो उच्च स्तर और उपयोग के अमूर्त पैटर्न को प्रस्तुत करता है, जो स्वयं अभिव्यक्ति भाषा के लागू उपयोग का एक उदाहरण है।

अभिव्यक्ति भाषा SQLAlchemy के मुख्य घटकों में से एक है। यह प्रोग्रामर को पायथन कोड में एसक्यूएल स्टेटमेंट निर्दिष्ट करने और सीधे अधिक जटिल प्रश्नों में इसका उपयोग करने की अनुमति देता है। अभिव्यक्ति की भाषा बैकेंड से स्वतंत्र है और व्यापक रूप से कच्चे एसक्यूएल के हर पहलू को कवर करती है। यह SQLAlchemy में किसी भी अन्य घटक की तुलना में कच्चे SQL के करीब है।

अभिव्यक्ति भाषा सीधे संबंधित डेटाबेस के आदिम निर्माण का प्रतिनिधित्व करती है। क्योंकि ORM अभिव्यक्ति भाषा के शीर्ष पर आधारित है, एक सामान्य पायथन डेटाबेस अनुप्रयोग ने दोनों के उपयोग को ओवरलैप किया हो सकता है। एप्लिकेशन अकेले अभिव्यक्ति भाषा का उपयोग कर सकता है, हालांकि इसे व्यक्तिगत डेटाबेस प्रश्नों में एप्लिकेशन अवधारणाओं के अनुवाद की अपनी प्रणाली को परिभाषित करना होगा।

अभिव्यक्ति भाषा के बयानों को SQLAlchemy इंजन द्वारा संबंधित कच्चे SQL प्रश्नों में अनुवादित किया जाएगा। अब हम सीखेंगे कि इंजन कैसे बनाया जाए और इसकी मदद से विभिन्न SQL क्वेरी को निष्पादित करें।

पिछले अध्याय में, हमने SQLAlchemy में अभिव्यक्ति भाषा के बारे में चर्चा की है। अब एक डेटाबेस से जुड़ने में शामिल कदमों की ओर बढ़ते हैं।

इंजन वर्ग जोड़ता है a Pool and Dialect together डेटाबेस का एक स्रोत प्रदान करने के लिए connectivity and behavior। इंजन वर्ग की एक वस्तु का उपयोग कर तत्काल किया जाता हैcreate_engine() समारोह।

Create_engine () फ़ंक्शन डेटाबेस को एक तर्क के रूप में लेता है। डेटाबेस को कहीं भी परिभाषित करने की आवश्यकता नहीं है। मानक कॉलिंग फॉर्म को URL को पहले स्थितीय तर्क के रूप में भेजना होता है, आमतौर पर एक स्ट्रिंग जो डेटाबेस बोली और कनेक्शन तर्क को इंगित करता है। नीचे दिए गए कोड का उपयोग करके, हम एक डेटाबेस बना सकते हैं।

>>> from sqlalchemy import create_engine
>>> engine = create_engine('sqlite:///college.db', echo = True)

के लिए MySQL database, नीचे कमांड का उपयोग करें -

engine = create_engine("mysql://user:pwd@localhost/college",echo = True)

विशेष रूप से उल्लेख करने के लिए DB-API कनेक्शन के लिए इस्तेमाल किया जाना है, URL string फार्म निम्नानुसार है -

dialect[+driver]://user:password@host/dbname

उदाहरण के लिए, यदि आप उपयोग कर रहे हैं PyMySQL driver with MySQL, निम्न कमांड का उपयोग करें -

mysql+pymysql://<username>:<password>@<host>/<dbname>

echo flagSQLAlchemy लॉगिंग सेट करने के लिए एक शॉर्टकट है, जो पायथन के मानक लॉगिंग मॉड्यूल के माध्यम से पूरा होता है। बाद के अध्यायों में, हम सभी उत्पन्न एसक्यूएल सीखेंगे। वर्बोज़ आउटपुट को छिपाने के लिए, इको विशेषता को सेट करेंNone। Create_engine () फ़ंक्शन के अन्य तर्क विशिष्ट बोली हो सकते हैं।

Create_engine () फ़ंक्शन एक रिटर्न देता है Engine object। इंजन क्लास के कुछ महत्वपूर्ण तरीके हैं -

अनु क्रमांक। विधि और विवरण
1

connect()

कनेक्शन ऑब्जेक्ट लौटाता है

2

execute()

SQL कथन निर्माण निष्पादित करता है

3

begin()

एक संदर्भ प्रबंधक की स्थापना के साथ एक कनेक्शन देने वाला रिटर्न देता है। सफल संचालन पर, लेन-देन प्रतिबद्ध है, अन्यथा इसे वापस ले लिया जाता है

4

dispose()

इंजन द्वारा उपयोग किए जाने वाले कनेक्शन पूल का निपटान

5

driver()

इंजन द्वारा उपयोग में बोली का ड्राइवर नाम

6

table_names()

डेटाबेस में उपलब्ध सभी तालिका नामों की सूची लौटाता है

7

transaction()

लेन-देन सीमा के भीतर दिए गए फ़ंक्शन को निष्पादित करता है

आइए अब चर्चा करते हैं कि क्रिएट टेबल फंक्शन का उपयोग कैसे करें।

एसक्यूएल एक्सप्रेशन लैंग्वेज टेबल स्तंभों के खिलाफ अपने भावों का निर्माण करती है। SQLAlchemy कॉलम ऑब्जेक्ट एक का प्रतिनिधित्व करता हैcolumn एक डेटाबेस तालिका में जो बदले में एक द्वारा प्रतिनिधित्व किया है Tableobject। मेटाडेटा में सारणी और संबंधित वस्तुओं जैसे सूचकांक, दृश्य, ट्रिगर, आदि की परिभाषाएं हैं।

इसलिए SQLAlchemy मेटाडेटा से मेटाडेटा वर्ग का एक ऑब्जेक्ट टेबल ऑब्जेक्ट्स और उनके संबंधित स्कीमा निर्माण का एक संग्रह है। यह टेबल ऑब्जेक्ट्स के संग्रह के साथ-साथ एक इंजन या कनेक्शन के लिए वैकल्पिक बाध्यकारी भी रखता है।

from sqlalchemy import MetaData
meta = MetaData()

मेटाडेटा वर्ग के निर्माता में बाइंड और स्कीमा पैरामीटर हो सकते हैं जो डिफ़ॉल्ट रूप से होते हैं None

इसके बाद, हम मेटाडेटा कैटलॉग के ऊपर अपनी तालिकाओं को परिभाषित करते हैं, उपयोग करते हुए the Table construct, जो नियमित एसक्यूएल क्रिएट टेबल स्टेटमेंट जैसा दिखता है।

तालिका वर्ग का ऑब्जेक्ट डेटाबेस में संबंधित तालिका का प्रतिनिधित्व करता है। कंस्ट्रक्टर निम्न पैरामीटर लेता है -

नाम तालिका का नाम
मेटाडाटा मेटाडेटा ऑब्जेक्ट जो इस तालिका को रखेगा
स्तंभ (रों) स्तंभ वर्ग की एक या एक से अधिक वस्तुएँ

कॉलम ऑब्जेक्ट एक का प्रतिनिधित्व करता है column में database table। कंस्ट्रक्टर नाम, प्रकार और अन्य मापदंडों जैसे प्राथमिक_की, स्वप्रतिबंध और अन्य बाधाओं को लेता है।

SQLAlchemy इसमें परिभाषित सर्वोत्तम संभव जेनेरिक कॉलम डेटा प्रकारों के लिए पायथन डेटा से मेल खाता है। कुछ सामान्य डेटा प्रकार हैं -

  • BigInteger
  • Boolean
  • Date
  • DateTime
  • Float
  • Integer
  • Numeric
  • SmallInteger
  • String
  • Text
  • Time

बनाने के लिए students table कॉलेज डेटाबेस में, निम्नलिखित स्निपेट का उपयोग करें -

from sqlalchemy import Table, Column, Integer, String, MetaData
meta = MetaData()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

Create_all () फ़ंक्शन सभी निर्धारित टेबल ऑब्जेक्ट बनाने के लिए इंजन ऑब्जेक्ट का उपयोग करता है और मेटाडेटा में जानकारी संग्रहीत करता है।

meta.create_all(engine)

पूरा कोड नीचे दिया गया है, जो इसमें छात्रों की तालिका के साथ एक SQLite डेटाबेस College.db बनाएगा।

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String),
)
meta.create_all(engine)

क्योंकि create_engine () फ़ंक्शन की गूंज विशेषता के लिए सेट है Trueकंसोल तालिका निर्माण के लिए वास्तविक SQL क्वेरी निम्नानुसार प्रदर्शित करेगा -

CREATE TABLE students (
   id INTEGER NOT NULL,
   name VARCHAR,
   lastname VARCHAR,
   PRIMARY KEY (id)
)

College.db को वर्तमान कार्यशील निर्देशिका में बनाया जाएगा। यह जाँचने के लिए कि क्या छात्र तालिका बनाई गई है, आप किसी भी SQLite GUI उपकरण का उपयोग करके डेटाबेस को खोल सकते हैंSQLiteStudio

नीचे दी गई छवि छात्रों को डेटाबेस में बनाई गई तालिका दिखाती है -

इस अध्याय में, हम संक्षेप में SQL एक्सप्रेशंस और उनके कार्यों पर ध्यान केंद्रित करेंगे।

लक्ष्य तालिका ऑब्जेक्ट के सापेक्ष संगत विधियों का उपयोग करके SQL अभिव्यक्तियों का निर्माण किया जाता है। उदाहरण के लिए, इन्सर्ट स्टेटमेंट इन्सर्ट को निष्पादित करके बनाया गया है () विधि निम्नानुसार है -

ins = students.insert()

उपरोक्त विधि का परिणाम एक सम्मिलित वस्तु है जिसका उपयोग करके सत्यापित किया जा सकता है str()समारोह। नीचे दिया गया कोड छात्र आईडी, नाम, अंतिम नाम जैसे विवरण सम्मिलित करता है।

'INSERT INTO students (id, name, lastname) VALUES (:id, :name, :lastname)'

द्वारा एक विशिष्ट क्षेत्र में मूल्य सम्मिलित करना संभव है values()वस्तु डालने की विधि। उसी के लिए कोड नीचे दिया गया है -

>>> ins = users.insert().values(name = 'Karan')
>>> str(ins)
'INSERT INTO users (name) VALUES (:name)'

पायथन कंसोल पर गाई गई एसक्यूएल वास्तविक मूल्य (इस मामले में 'करण') नहीं दिखाती है। इसके बजाय, SQLALchemy एक बाइंड पैरामीटर बनाता है जो कथन के संकलित रूप में दिखाई देता है।

ins.compile().params
{'name': 'Karan'}

इसी तरह से तरीके update(), delete() तथा select()क्रमशः अद्यतन, DELETE और चयन अभिव्यक्तियाँ बनाएँ। हम बाद के अध्यायों में उनके बारे में जानेंगे।

पिछले अध्याय में, हमने SQL एक्सप्रेशंस सीखा है। इस अध्याय में, हम इन भावों के निष्पादन पर ध्यान देंगे।

परिणामी SQL अभिव्यक्तियों को निष्पादित करने के लिए, हमें करना होगा obtain a connection object representing an actively checked out DBAPI connection resource और फिर feed the expression object जैसा कि नीचे दिए गए कोड में दिखाया गया है।

conn = engine.connect()

निम्नलिखित सम्मिलित () ऑब्जेक्ट का उपयोग निष्पादन के लिए किया जा सकता है () विधि -

ins = students.insert().values(name = 'Ravi', lastname = 'Kapoor')
result = conn.execute(ins)

कंसोल नीचे के रूप में SQL अभिव्यक्ति के निष्पादन का परिणाम दिखाता है -

INSERT INTO students (name, lastname) VALUES (?, ?)
('Ravi', 'Kapoor')
COMMIT

निम्नलिखित संपूर्ण स्निपेट है जो SQLAlchemy की मूल तकनीक का उपयोग करके INSERT क्वेरी के निष्पादन को दर्शाता है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

ins = students.insert()
ins = students.insert().values(name = 'Ravi', lastname = 'Kapoor')
conn = engine.connect()
result = conn.execute(ins)

नीचे स्क्रीनशॉट में दिखाए अनुसार SQLite Studio का उपयोग करके डेटाबेस को खोलकर परिणाम को सत्यापित किया जा सकता है -

परिणाम चर को ResultProxy के रूप में जाना जाता है object। यह DBAPI कर्सर ऑब्जेक्ट के अनुरूप है। हम उन प्राथमिक प्रमुख मूल्यों के बारे में जानकारी प्राप्त कर सकते हैं जो हमारे कथन के उपयोग से उत्पन्न हुए थेResultProxy.inserted_primary_key जैसा कि नीचे दिखाया गया है -

result.inserted_primary_key
[1]

डीबीएपीआई की कई () विधि का उपयोग करके कई आवेषण जारी करने के लिए, हम उन सभी शब्दकोशों की सूची में भेज सकते हैं जिनमें प्रत्येक पैरामीटर को सम्मिलित किया जाना है।

conn.execute(students.insert(), [
   {'name':'Rajiv', 'lastname' : 'Khanna'},
   {'name':'Komal','lastname' : 'Bhandari'},
   {'name':'Abdul','lastname' : 'Sattar'},
   {'name':'Priya','lastname' : 'Rajhans'},
])

यह तालिका के डेटा दृश्य में परिलक्षित होता है जैसा कि निम्न आकृति में दिखाया गया है -

इस अध्याय में, हम तालिका ऑब्जेक्ट में पंक्तियों के चयन की अवधारणा के बारे में चर्चा करेंगे।

टेबल ऑब्जेक्ट का चयन () विधि हमें सक्षम बनाता है construct SELECT expression

s = students.select()

चयनित वस्तु में अनुवाद होता है SELECT query by str(s) function जैसा कि नीचे दिखाया गया है -

'SELECT students.id, students.name, students.lastname FROM students'

हम इस वस्तु का चयन करने के लिए एक पैरामीटर के रूप में उपयोग कर सकते हैं () कनेक्शन वस्तु का तरीका नीचे दिए गए कोड में दिखाया गया है -

result = conn.execute(s)

जब उपरोक्त कथन निष्पादित किया जाता है, पायथन शेल समान एसक्यूएल अभिव्यक्ति के बाद गूँजता है -

SELECT students.id, students.name, students.lastname
FROM students

परिणामी चर DBAPI में कर्सर के बराबर है। अब हम रिकॉर्ड का उपयोग करके प्राप्त कर सकते हैंfetchone() method

row = result.fetchone()

तालिका में सभी चयनित पंक्तियों को एक द्वारा मुद्रित किया जा सकता है for loop जैसा कि नीचे दिया गया है -

for row in result:
   print (row)

छात्रों की तालिका से सभी पंक्तियों को मुद्रित करने का पूरा कोड नीचे दिखाया गया है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

s = students.select()
conn = engine.connect()
result = conn.execute(s)

for row in result:
   print (row)

पायथन शेल में दिखाया गया उत्पादन निम्नानुसार है -

(1, 'Ravi', 'Kapoor')
(2, 'Rajiv', 'Khanna')
(3, 'Komal', 'Bhandari')
(4, 'Abdul', 'Sattar')
(5, 'Priya', 'Rajhans')

जहां चयन क्वेरी का क्लॉज का उपयोग करके लागू किया जा सकता है Select.where()। उदाहरण के लिए, यदि हम id> 2 के साथ पंक्तियों को प्रदर्शित करना चाहते हैं

s = students.select().where(students.c.id>2)
result = conn.execute(s)

for row in result:
   print (row)

यहाँ c attribute is an alias for column। निम्नलिखित उत्पादन शेल पर प्रदर्शित किया जाएगा -

(3, 'Komal', 'Bhandari')
(4, 'Abdul', 'Sattar')
(5, 'Priya', 'Rajhans')

यहां, हमें यह ध्यान रखना होगा कि sqlalchemy.sql मॉड्यूल में चुनिंदा () फ़ंक्शन द्वारा भी ऑब्जेक्ट प्राप्त किया जा सकता है। चयन () फ़ंक्शन को तर्क के रूप में टेबल ऑब्जेक्ट की आवश्यकता होती है।

from sqlalchemy.sql import select
s = select([users])
result = conn.execute(s)

SQLAlchemy आपको स्ट्रिंग्स का उपयोग करने देता है, उन मामलों के लिए जब SQL पहले से ही जाना जाता है और डायनामिक सुविधाओं का समर्थन करने के लिए कथन की मजबूत आवश्यकता नहीं है। पाठ () निर्माण का उपयोग एक शाब्दिक कथन की रचना करने के लिए किया जाता है जो डेटाबेस में ज्यादातर अपरिवर्तित होता है।

यह एक नया निर्माण करता है TextClauseनीचे दिए गए कोड में दिखाए गए अनुसार एक सीधे एसक्यूएल स्ट्रिंग का प्रतिनिधित्व करते हुए -

from sqlalchemy import text
t = text("SELECT * FROM students")
result = connection.execute(t)

फायदे text() एक सादे तार पर उपलब्ध हैं -

  • बाइंड मापदंडों के लिए बैकएंड-तटस्थ समर्थन
  • प्रति कथन निष्पादन विकल्प
  • परिणाम-स्तंभ टाइपिंग व्यवहार

पाठ () फ़ंक्शन को नामित कॉलोन प्रारूप में बाध्य मापदंडों की आवश्यकता होती है। वे डेटाबेस बैकएंड की परवाह किए बिना सुसंगत हैं। मापदंडों के लिए मान भेजने के लिए, हम उन्हें अतिरिक्त तर्कों के रूप में निष्पादित () विधि में पास करते हैं।

निम्नलिखित उदाहरण पाठ एसक्यूएल में बाध्य मापदंडों का उपयोग करता है -

from sqlalchemy.sql import text
s = text("select students.name, students.lastname from students where students.name between :x and :y")
conn.execute(s, x = 'A', y = 'L').fetchall()

पाठ () फ़ंक्शन SQL अभिव्यक्ति का निर्माण निम्नानुसार करता है -

select students.name, students.lastname from students where students.name between ? and ?

X = 'A' और y = 'L' के मान को मापदंडों के रूप में पारित किया जाता है। परिणाम 'A' और 'L' के नाम वाली पंक्तियों की एक सूची है -

[('Komal', 'Bhandari'), ('Abdul', 'Sattar')]

पाठ () निर्माण TextClause.bindparams () पद्धति का उपयोग करके पूर्व-स्थापित बाध्य मानों का समर्थन करता है। मापदंडों को स्पष्ट रूप से निम्न प्रकार से टाइप किया जा सकता है -

stmt = text("SELECT * FROM students WHERE students.name BETWEEN :x AND :y")

stmt = stmt.bindparams(
   bindparam("x", type_= String), 
   bindparam("y", type_= String)
)

result = conn.execute(stmt, {"x": "A", "y": "L"})

The text() function also be produces fragments of SQL within a select() object that 
accepts text() objects as an arguments. The “geometry” of the statement is provided by 
select() construct , and the textual content by text() construct. We can build a statement 
without the need to refer to any pre-established Table metadata. 

from sqlalchemy.sql import select
s = select([text("students.name, students.lastname from students")]).where(text("students.name between :x and :y"))
conn.execute(s, x = 'A', y = 'L').fetchall()

आप भी उपयोग कर सकते हैं and_() पाठ () फ़ंक्शन की सहायता से WHERE क्लॉज़ में कई स्थितियों को संयोजित करने के लिए फ़ंक्शन।

from sqlalchemy import and_
from sqlalchemy.sql import select
s = select([text("* from students")]) \
.where(
   and_(
      text("students.name between :x and :y"),
      text("students.id>2")
   )
)
conn.execute(s, x = 'A', y = 'L').fetchall()

उपरोक्त कोड में "A" और "L" के बीच के नाम के साथ पंक्तियाँ हैं। आईडी से अधिक 2. कोड का आउटपुट नीचे दिया गया है -

[(3, 'Komal', 'Bhandari'), (4, 'Abdul', 'Sattar')]

SQL में उपनाम टेबल या SELECT स्टेटमेंट के "पुनर्नामित" संस्करण से मेल खाता है, जो कभी भी आपके द्वारा "SELECT * FROM table1 AS" कहने पर होता है। एएस तालिका के लिए एक नया नाम बनाता है। उपनाम किसी भी तालिका या उपश्रेणी को एक अद्वितीय नाम से संदर्भित करने की अनुमति देते हैं।

तालिका के मामले में, यह एक ही तालिका को कई बार FROM क्लॉज में नामित करने की अनुमति देता है। यह कथन द्वारा प्रस्तुत कॉलम के लिए एक मूल नाम प्रदान करता है, जिससे उन्हें इस नाम के सापेक्ष संदर्भित किया जा सकता है।

SQLAlchemy में, किसी भी तालिका, चयन () निर्माण, या अन्य चयन करने योग्य वस्तु का उपयोग कर एक उपनाम में बदल दिया जा सकता है From Clause.alias()विधि, जो एक उपनाम निर्माण करता है। Sqlalchemy.sql मॉड्यूल में उपनाम () फ़ंक्शन एक उपनाम का प्रतिनिधित्व करता है, जैसा कि आम तौर पर एएस कीवर्ड का उपयोग करके SQL कथन के भीतर किसी तालिका या उप-चयन पर लागू होता है।

from sqlalchemy.sql import alias
st = students.alias("a")

इस उपनाम का उपयोग अब छात्रों की तालिका को संदर्भित करने के लिए चुनिंदा () निर्माण में किया जा सकता है -

s = select([st]).where(st.c.id>2)

यह एसक्यूएल अभिव्यक्ति के लिए अनुवाद इस प्रकार है -

SELECT a.id, a.name, a.lastname FROM students AS a WHERE a.id > 2

अब हम कनेक्शन ऑब्जेक्ट के एग्जीक्यूट () विधि के साथ इस SQL ​​क्वेरी को निष्पादित कर सकते हैं। पूरा कोड इस प्रकार है -

from sqlalchemy.sql import alias, select
st = students.alias("a")
s = select([st]).where(st.c.id > 2)
conn.execute(s).fetchall()

जब कोड के ऊपर लाइन निष्पादित की जाती है, तो यह निम्न आउटपुट उत्पन्न करता है -

[(3, 'Komal', 'Bhandari'), (4, 'Abdul', 'Sattar'), (5, 'Priya', 'Rajhans')]

update() लक्ष्य तालिका ऑब्जेक्ट पर विधि समरूप UPDATE SQL अभिव्यक्ति का निर्माण करती है।

table.update().where(conditions).values(SET expressions)

values()परिणाम अद्यतन अद्यतन विधि का उपयोग UPDATE की SET शर्तों को निर्दिष्ट करने के लिए किया जाता है। यदि किसी के रूप में नहीं छोड़ा जाता है, तो एसईटी की स्थिति उन मापदंडों से निर्धारित की जाती है जो कथन के निष्पादन और / या संकलन के दौरान बयान में दिए गए हैं।

जहाँ क्लॉज एक वैकल्पिक अभिव्यक्ति है, जो विवरण कथन की स्थिति के बारे में बताती है।

निम्नलिखित कोड स्निपेट ने छात्रों के टेबल में 'खन्ना' से 'कपूर' तक 'अंतिम नाम' कॉलम का मान बदल दिया -

stmt = students.update().where(students.c.lastname == 'Khanna').values(lastname = 'Kapoor')

Stmt वस्तु एक अद्यतन वस्तु है जिसका अनुवाद है -

'UPDATE students SET lastname = :lastname WHERE students.lastname = :lastname_1'

बाध्य पैरामीटर lastname_1 जब प्रतिस्थापित किया जाएगा execute()विधि लागू है। पूरा अपडेट कोड नीचे दिया गया है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()

students = Table(
   'students', 
   meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

conn = engine.connect()
stmt=students.update().where(students.c.lastname=='Khanna').values(lastname='Kapoor')
conn.execute(stmt)
s = students.select()
conn.execute(s).fetchall()

उपरोक्त कोड दूसरी पंक्ति के साथ आउटपुट के बाद प्रदर्शित होता है जैसे कि अपडेट ऑपरेशन का प्रभाव स्क्रीनशॉट में दिया गया है -

[
   (1, 'Ravi', 'Kapoor'),
   (2, 'Rajiv', 'Kapoor'),
   (3, 'Komal', 'Bhandari'),
   (4, 'Abdul', 'Sattar'),
   (5, 'Priya', 'Rajhans')
]

ध्यान दें कि समान कार्यक्षमता का उपयोग करके भी प्राप्त किया जा सकता है update() नीचे दिखाए अनुसार sqlalchemy.sql.expression मॉड्यूल में कार्य -

from sqlalchemy.sql.expression import update
stmt = update(students).where(students.c.lastname == 'Khanna').values(lastname = 'Kapoor')

पिछले अध्याय में, हम समझ चुके हैं कि क्या है Updateअभिव्यक्ति करता है। अगली अभिव्यक्ति जो हम सीखने जा रहे हैं वह हैDelete

निम्न कथन में दिए गए लक्ष्य तालिका ऑब्जेक्ट पर डिलीट () विधि चलाकर डिलीट ऑपरेशन को प्राप्त किया जा सकता है -

stmt = students.delete()

छात्रों की तालिका के मामले में, कोड की उपरोक्त रेखा एक SQL अभिव्यक्ति का निर्माण करती है -

'DELETE FROM students'

हालांकि, यह छात्रों की तालिका में सभी पंक्तियों को हटा देगा। आमतौर पर DELETE क्वेरी WHERE क्लॉज द्वारा निर्दिष्ट एक तार्किक अभिव्यक्ति के साथ जुड़ा हुआ है। निम्न कथन दिखाता है कि पैरामीटर कहाँ है -

stmt = students.delete().where(students.c.id > 2)

परिणामी SQL अभिव्यक्ति में एक बाउंड पैरामीटर होगा जिसे स्टेटमेंट निष्पादित होने पर रनटाइम पर प्रतिस्थापित किया जाएगा।

'DELETE FROM students WHERE students.id > :id_1'

कोड उदाहरण के बाद छात्रों की तालिका से उन पंक्तियों को हटा दिया जाएगा जिनमें अंतिम नाम 'खन्ना' है -

from sqlalchemy.sql.expression import update
from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)

meta = MetaData()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

conn = engine.connect()
stmt = students.delete().where(students.c.lastname == 'Khanna')
conn.execute(stmt)
s = students.select()
conn.execute(s).fetchall()

परिणाम सत्यापित करने के लिए, SQLiteStudio में छात्रों की तालिका के डेटा दृश्य को ताज़ा करें।

RDBMS की महत्वपूर्ण विशेषताओं में से एक तालिकाओं के बीच संबंध स्थापित करना है। SQL संचालन जैसे SELECT, UPDATE और DELETE संबंधित तालिकाओं पर किए जा सकते हैं। यह अनुभाग SQLAlchemy का उपयोग करके इन ऑपरेशनों का वर्णन करता है।

इस प्रयोजन के लिए, हमारे SQLite डेटाबेस (College.db) में दो टेबल बनाए गए हैं। छात्रों की तालिका में वही संरचना है जो पिछले अनुभाग में दी गई है; जबकि पते की मेज हैst_id स्तंभ जिसे मैप किया गया है id column in students table विदेशी कुंजी का उपयोग करना।

निम्नलिखित कोड College.db में दो टेबल बनाएगा -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, ForeignKey
engine = create_engine('sqlite:///college.db', echo=True)
meta = MetaData()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

addresses = Table(
   'addresses', meta, 
   Column('id', Integer, primary_key = True), 
   Column('st_id', Integer, ForeignKey('students.id')), 
   Column('postal_add', String), 
   Column('email_add', String))

meta.create_all(engine)

उपरोक्त कोड छात्रों और पते तालिका के लिए नीचे दिए गए प्रश्नों के लिए अनुवाद करेगा -

CREATE TABLE students (
   id INTEGER NOT NULL,
   name VARCHAR,
   lastname VARCHAR,
   PRIMARY KEY (id)
)

CREATE TABLE addresses (
   id INTEGER NOT NULL,
   st_id INTEGER,
   postal_add VARCHAR,
   email_add VARCHAR,
   PRIMARY KEY (id),
   FOREIGN KEY(st_id) REFERENCES students (id)
)

निम्नलिखित स्क्रीनशॉट उपरोक्त कोड को बहुत स्पष्ट रूप से प्रस्तुत करते हैं -

इन तालिकाओं को निष्पादित करके डेटा के साथ आबाद किया जाता है insert() methodटेबल ऑब्जेक्ट्स की। छात्रों की तालिका में 5 पंक्तियाँ डालने के लिए, आप नीचे दिए गए कोड का उपयोग कर सकते हैं -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()

conn = engine.connect()
students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

conn.execute(students.insert(), [
   {'name':'Ravi', 'lastname':'Kapoor'},
   {'name':'Rajiv', 'lastname' : 'Khanna'},
   {'name':'Komal','lastname' : 'Bhandari'},
   {'name':'Abdul','lastname' : 'Sattar'},
   {'name':'Priya','lastname' : 'Rajhans'},
])

Rows निम्नलिखित कोड की मदद से पता तालिका में जोड़ा जाता है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()
conn = engine.connect()

addresses = Table(
   'addresses', meta, 
   Column('id', Integer, primary_key = True), 
   Column('st_id', Integer), 
   Column('postal_add', String), 
   Column('email_add', String)
)

conn.execute(addresses.insert(), [
   {'st_id':1, 'postal_add':'Shivajinagar Pune', 'email_add':'[email protected]'},
   {'st_id':1, 'postal_add':'ChurchGate Mumbai', 'email_add':'[email protected]'},
   {'st_id':3, 'postal_add':'Jubilee Hills Hyderabad', 'email_add':'[email protected]'},
   {'st_id':5, 'postal_add':'MG Road Bangaluru', 'email_add':'[email protected]'},
   {'st_id':2, 'postal_add':'Cannought Place new Delhi', 'email_add':'[email protected]'},
])

ध्यान दें कि पता तालिका में st_id कॉलम छात्रों की तालिका में id कॉलम को संदर्भित करता है। अब हम दोनों तालिकाओं से डेटा लाने के लिए इस संबंध का उपयोग कर सकते हैं। हम लाना चाहते हैंname तथा lastname छात्रों की तालिका से पता तालिका में st_id के अनुरूप।

from sqlalchemy.sql import select
s = select([students, addresses]).where(students.c.id == addresses.c.st_id)
result = conn.execute(s)

for row in result:
   print (row)

चुनिंदा वस्तुएं प्रभावी रूप से सामान्य अभिव्यक्ति पर दो तालिकाओं में शामिल होने वाली एसक्यूएल अभिव्यक्ति का अनुसरण करेगी -

SELECT students.id, 
   students.name, 
   students.lastname, 
   addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM students, addresses
WHERE students.id = addresses.st_id

यह दोनों तालिकाओं से संबंधित डेटा निकालने का उत्पादन निम्नानुसार करेगा -

(1, 'Ravi', 'Kapoor', 1, 1, 'Shivajinagar Pune', '[email protected]')
(1, 'Ravi', 'Kapoor', 2, 1, 'ChurchGate Mumbai', '[email protected]')
(3, 'Komal', 'Bhandari', 3, 3, 'Jubilee Hills Hyderabad', '[email protected]')
(5, 'Priya', 'Rajhans', 4, 5, 'MG Road Bangaluru', '[email protected]')
(2, 'Rajiv', 'Khanna', 5, 2, 'Cannought Place new Delhi', '[email protected]')

पिछले अध्याय में, हमने कई तालिकाओं का उपयोग करने के बारे में चर्चा की है। इसलिए हम एक कदम आगे बढ़ते हैं और सीखते हैंmultiple table updates इस पाठ में।

SQLAlchemy की तालिका ऑब्जेक्ट का उपयोग करते हुए, एक से अधिक तालिका को अपडेट () विधि के WHERE क्लॉज में निर्दिष्ट किया जा सकता है। PostgreSQL और Microsoft SQL सर्वर कई तालिकाओं के संदर्भ में अद्यतन कथन का समर्थन करते हैं। यह लागू करता है“UPDATE FROM”सिंटैक्स, जो एक बार में एक टेबल को अपडेट करता है। हालांकि, अतिरिक्त तालिकाओं को सीधे "अतिरिक्त" खंड में संदर्भित किया जा सकता है, जहां सीधे खंड में। कोड की निम्नलिखित पंक्तियों की अवधारणा को समझाते हैंmultiple table updates स्पष्ट रूप से।

stmt = students.update().\
values({
   students.c.name:'xyz',
   addresses.c.email_add:'[email protected]'
}).\
where(students.c.id == addresses.c.id)

अद्यतन वस्तु निम्नलिखित अद्यतन क्वेरी के बराबर है -

UPDATE students 
SET email_add = :addresses_email_add, name = :name 
FROM addresses 
WHERE students.id = addresses.id

जहां तक ​​MySQL बोली का संबंध है, एकाधिक तालिकाओं को एक अल्पविराम स्टेटमेंट में एक अल्पविराम द्वारा अलग किया जा सकता है जैसा कि नीचे दिया गया है -

stmt = students.update().\
   values(name = 'xyz').\
   where(students.c.id == addresses.c.id)

निम्न कोड में परिणामी क्वेरी क्वेरी को दर्शाया गया है -

'UPDATE students SET name = :name 
FROM addresses 
WHERE students.id = addresses.id'

SQLite बोली हालांकि UPDATE के भीतर कई-तालिका मानदंडों का समर्थन नहीं करती है और निम्नलिखित त्रुटि दिखाती है -

NotImplementedError: This backend does not support multiple-table criteria within UPDATE

कच्चे SQL की अद्यतन क्वेरी में सेट क्लॉज है। यह मूल तालिका तालिका में दिए गए स्तंभ क्रम का उपयोग करके अद्यतन () निर्माण द्वारा प्रदान किया गया है। इसलिए, विशेष कॉलम के साथ एक विशेष अद्यतन स्टेटमेंट को हर बार समान रूप से प्रस्तुत किया जाएगा। चूंकि पैरामीटर खुद को पायथन डिक्शनरी कुंजियों के रूप में Update.values ​​() पद्धति में भेजते हैं, इसलिए कोई अन्य निश्चित आदेश उपलब्ध नहीं है।

कुछ मामलों में, एसईटी क्लॉज में दिए गए मापदंडों का क्रम महत्वपूर्ण है। MySQL में, स्तंभ मानों को अपडेट प्रदान करना अन्य स्तंभ मानों पर आधारित है।

निम्नलिखित कथन का परिणाम -

UPDATE table1 SET x = y + 10, y = 20

की तुलना में एक अलग परिणाम होगा -

UPDATE table1 SET y = 20, x = y + 10

MySQL में SET क्लॉज का मूल्यांकन प्रति-मूल्य के आधार पर किया जाता है न कि प्रति-पंक्ति के आधार पर। इस उद्देश्य के लिए,preserve_parameter_orderप्रयोग किया जाता है। 2-ट्यूपल्स की पायथन लिस्ट को तर्क के रूप में दिया गया हैUpdate.values() विधि -

stmt = table1.update(preserve_parameter_order = True).\
   values([(table1.c.y, 20), (table1.c.x, table1.c.y + 10)])

सूची ऑब्जेक्ट शब्दकोश के समान है सिवाय इसके कि यह आदेश दिया गया है। यह सुनिश्चित करता है कि "y" कॉलम का SET क्लॉज पहले रेंडर करेगा, फिर "x" कॉलम का SET क्लॉज।

इस अध्याय में, हम मल्टीपल टेबल डीलेट्स एक्सप्रेशन में देखेंगे जो मल्टीपल टेबल अपडेट्स फंक्शन का उपयोग करने के समान है।

कई DBMS बोलियों में DELETE स्टेटमेंट के एक से अधिक टेबल को संदर्भित किया जा सकता है। PG और MySQL के लिए, “DELETE USING” वाक्य रचना का उपयोग किया जाता है; और SQL सर्वर के लिए, "DELETE FROM" अभिव्यक्ति का उपयोग करके एक से अधिक तालिका को संदर्भित करता है। SQLAlchemydelete() निर्माण इन दोनों मोडों का समर्थन करता है, जैसा कि निम्न तालिका में कई तालिकाओं को निर्दिष्ट करके -

stmt = users.delete().\
   where(users.c.id == addresses.c.id).\
   where(addresses.c.email_address.startswith('xyz%'))
conn.execute(stmt)

PostgreSQL बैकएंड पर, उपरोक्त कथन से परिणामी SQL इस प्रकार प्रस्तुत करेगी -

DELETE FROM users USING addresses
WHERE users.id = addresses.id
AND (addresses.email_address LIKE %(email_address_1)s || '%%')

यदि इस पद्धति का उपयोग एक डेटाबेस के साथ किया जाता है जो इस व्यवहार का समर्थन नहीं करता है, तो संकलक NotImplementedError बढ़ाएगा।

इस अध्याय में, हम सीखेंगे कि SQLAlchemy में Joins का उपयोग कैसे करें।

ज्वाइनिंग का प्रभाव केवल दो तालिकाओं को रखने से प्राप्त होता है columns clause या where clauseका चयन करें () निर्माण। अब हम जॉइन () और आउटरजॉइन () विधियों का उपयोग करते हैं।

ज्वाइन () विधि एक टेबल ऑब्जेक्ट से दूसरे में ज्वाइन ऑब्जेक्ट लौटाता है।

join(right, onclause = None, isouter = False, full = False)

उपरोक्त कोड में उल्लिखित मापदंडों के कार्य निम्नानुसार हैं -

  • right- सम्मिलित होने के दाईं ओर; यह किसी भी टेबल ऑब्जेक्ट है

  • onclause- एक एसक्यूएल अभिव्यक्ति में शामिल होने के खंड पर प्रतिनिधित्व करते हैं। यदि किसी को भी नहीं छोड़ा गया है, तो यह विदेशी कुंजी संबंध के आधार पर दो तालिकाओं में शामिल होने का प्रयास करता है

  • isouter - अगर सही है, जोइन के बजाय एक बाईं ओर जॉय प्रस्तुत करता है

  • full - अगर सही है, तो लेफ्टिनेंट ओस्टर जॉइन की जगह एक फुल ऑर्टिन जॉय प्रस्तुत करता है

उदाहरण के लिए, ज्वाइन () विधि का उपयोग करने पर विदेशी कुंजी के आधार पर स्वचालित रूप से जॉइन हो जाएगा।

>>> print(students.join(addresses))

यह एसक्यूएल अभिव्यक्ति के समतुल्य है -

students JOIN addresses ON students.id = addresses.st_id

आप स्पष्ट रूप से शामिल होने के मानदंडों का उल्लेख कर सकते हैं -

j = students.join(addresses, students.c.id == addresses.c.st_id)

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

stmt = select([students]).select_from(j)

यह SQL अभिव्यक्ति के बाद परिणाम होगा -

SELECT students.id, students.name, students.lastname
FROM students JOIN addresses ON students.id = addresses.st_id

यदि इस कथन को इंजन का प्रतिनिधित्व करने वाले कनेक्शन का उपयोग करके निष्पादित किया जाता है, तो चयनित कॉलम से संबंधित डेटा प्रदर्शित किया जाएगा। पूरा कोड इस प्रकार है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, ForeignKey
engine = create_engine('sqlite:///college.db', echo = True)

meta = MetaData()
conn = engine.connect()
students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

addresses = Table(
   'addresses', meta, 
   Column('id', Integer, primary_key = True), 
   Column('st_id', Integer,ForeignKey('students.id')), 
   Column('postal_add', String), 
   Column('email_add', String)
)

from sqlalchemy import join
from sqlalchemy.sql import select
j = students.join(addresses, students.c.id == addresses.c.st_id)
stmt = select([students]).select_from(j)
result = conn.execute(stmt)
result.fetchall()

उपरोक्त कोड का आउटपुट निम्न है -

[
   (1, 'Ravi', 'Kapoor'),
   (1, 'Ravi', 'Kapoor'),
   (3, 'Komal', 'Bhandari'),
   (5, 'Priya', 'Rajhans'),
   (2, 'Rajiv', 'Khanna')
]

Conjunctions SQLAlchemy मॉड्यूल में कार्य करते हैं जो SQL अभिव्यक्तियों में प्रयुक्त रिलेशनल ऑपरेटरों को लागू करते हैं। ऑपरेटरों और, या, नहीं, आदि का उपयोग दो अलग-अलग तार्किक अभिव्यक्तियों को मिलाकर एक यौगिक अभिव्यक्ति बनाने के लिए किया जाता है। और SELECT स्टेटमेंट में उपयोग करने का एक सरल उदाहरण इस प्रकार है -

SELECT * from EMPLOYEE WHERE salary>10000 AND age>30

SQLAlchemy फ़ंक्शंस और_ (), or_ () और not_ () क्रमशः लागू AND, OR और NOT ऑपरेटर।

और_ () फ़ंक्शन

यह AND से जुड़कर अभिव्यक्तियों का एक संयोजन बनाता है। एक उदाहरण बेहतर समझ के लिए नीचे दिया गया है -

from sqlalchemy import and_

print(
   and_(
      students.c.name == 'Ravi',
      students.c.id <3
   )
)

यह अनुवाद -

students.name = :name_1 AND students.id < :id_1

छात्रों की मेज पर एक चयन () निर्माण में and_ () का उपयोग करने के लिए, कोड की निम्नलिखित पंक्ति का उपयोग करें -

stmt = select([students]).where(and_(students.c.name == 'Ravi', students.c.id <3))

निम्नलिखित प्रकृति के चयनित कथन का निर्माण किया जाएगा -

SELECT students.id, 
   students.name, 
   students.lastname
FROM students
WHERE students.name = :name_1 AND students.id < :id_1

पूरा कोड जो उपरोक्त SELECT क्वेरी का आउटपुट प्रदर्शित करता है वह इस प्रकार है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, ForeignKey, select
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()
conn = engine.connect()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

from sqlalchemy import and_, or_
stmt = select([students]).where(and_(students.c.name == 'Ravi', students.c.id <3))
result = conn.execute(stmt)
print (result.fetchall())

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

[(1, 'Ravi', 'Kapoor')]

या_ () फ़ंक्शन

यह OR से जुड़ने वाले भावों के संयोजन का निर्माण करता है। हम निम्नलिखित उदाहरण में or_ () का उपयोग करते हुए stmt ऑब्जेक्ट को निम्न में से बदल देंगे

stmt = select([students]).where(or_(students.c.name == 'Ravi', students.c.id <3))

जो प्रभावी रूप से चयनित क्वेरी के समतुल्य होगा -

SELECT students.id, 
   students.name, 
   students.lastname
FROM students
WHERE students.name = :name_1 
OR students.id < :id_1

एक बार जब आप प्रतिस्थापन बनाते हैं और उपरोक्त कोड चलाते हैं, तो परिणाम OR स्थिति में आने वाली दो पंक्तियाँ होंगी -

[(1, 'Ravi', 'Kapoor'),
(2, 'Rajiv', 'Khanna')]

asc () फ़ंक्शन

यह क्लाज द्वारा आरोही क्रम का उत्पादन करता है। फ़ंक्शन को पैरामीटर के रूप में लागू करने के लिए फ़ंक्शन कॉलम लेता है।

from sqlalchemy import asc
stmt = select([students]).order_by(asc(students.c.name))

एसक्यूएल अभिव्यक्ति के बाद कथन लागू होता है -

SELECT students.id, 
   students.name, 
   students.lastname
FROM students 
ORDER BY students.name ASC

निम्नलिखित कोड छात्रों के नाम तालिका के आरोही क्रम में तालिका के सभी रिकॉर्डों को सूचीबद्ध करता है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, ForeignKey, select
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()
conn = engine.connect()

students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

from sqlalchemy import asc
stmt = select([students]).order_by(asc(students.c.name))
result = conn.execute(stmt)

for row in result:
   print (row)

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

(4, 'Abdul', 'Sattar')
(3, 'Komal', 'Bhandari')
(5, 'Priya', 'Rajhans')
(2, 'Rajiv', 'Khanna')
(1, 'Ravi', 'Kapoor')

desc () फ़ंक्शन

इसी प्रकार अवरोही () फ़ंक्शन निम्न प्रकार से अवरोही क्रम से उत्पन्न होता है -

from sqlalchemy import desc
stmt = select([students]).order_by(desc(students.c.lastname))

समकक्ष SQL अभिव्यक्ति है -

SELECT students.id, 
   students.name, 
   students.lastname
FROM students 
ORDER BY students.lastname DESC

और कोड की उपरोक्त लाइनों के लिए आउटपुट है -

(4, 'Abdul', 'Sattar')
(5, 'Priya', 'Rajhans')
(2, 'Rajiv', 'Khanna')
(1, 'Ravi', 'Kapoor')
(3, 'Komal', 'Bhandari')

() फ़ंक्शन के बीच

यह एक BETWEEN विधेय खंड का उत्पादन करता है। यह आम तौर पर मान्य करने के लिए उपयोग किया जाता है यदि किसी निश्चित स्तंभ का मान किसी श्रेणी के बीच आता है। उदाहरण के लिए, निम्नलिखित कोड पंक्तियों का चयन करता है जिसके लिए आईडी कॉलम 2 और 4 के बीच है -

from sqlalchemy import between
stmt = select([students]).where(between(students.c.id,2,4))
print (stmt)

परिणामस्वरूप SQL अभिव्यक्ति जैसा दिखता है -

SELECT students.id, 
   students.name, 
   students.lastname
FROM students
WHERE students.id 
BETWEEN :id_1 AND :id_2

और परिणाम इस प्रकार है -

(2, 'Rajiv', 'Khanna')
(3, 'Komal', 'Bhandari')
(4, 'Abdul', 'Sattar')

SQLAlchemy में उपयोग किए गए कुछ महत्वपूर्ण कार्यों की चर्चा इस अध्याय में की गई है।

मानक SQL ने कई कार्यों की सिफारिश की है जो अधिकांश बोलियों द्वारा कार्यान्वित किए जाते हैं। वे इसके लिए पारित तर्कों के आधार पर एक एकल मान लौटाते हैं। कुछ SQL फ़ंक्शन तर्कों के रूप में कॉलम लेते हैं जबकि कुछ सामान्य हैं।Thefunc keyword in SQLAlchemy API is used to generate these functions

SQL में, अब () एक सामान्य कार्य है। निम्नलिखित कथनों का उपयोग फंक का उपयोग करके अब () फ़ंक्शन प्रदान करता है -

from sqlalchemy.sql import func
result = conn.execute(select([func.now()]))
print (result.fetchone())

उपरोक्त कोड का नमूना परिणाम नीचे दिखाया जा सकता है -

(datetime.datetime(2018, 6, 16, 6, 4, 40),)

दूसरी ओर, गणना () फ़ंक्शन जो तालिका से चुनी गई पंक्तियों की संख्या देता है, का उपयोग फंक के उपयोग द्वारा किया जाता है -

from sqlalchemy.sql import func
result = conn.execute(select([func.count(students.c.id)]))
print (result.fetchone())

उपरोक्त कोड से, छात्रों की तालिका में पंक्तियों की संख्या की गणना की जाएगी।

कुछ अंतर्निहित SQL फ़ंक्शन निम्न डेटा के साथ कर्मचारी तालिका का उपयोग करके दिखाए जाते हैं -

ईद नाम निशान
1 कमल 56
2 फर्नांडीज 85
3 सुनील 62
4 भास्कर 76

अधिकतम () फ़ंक्शन SQLAlchemy से दुर्गंध के उपयोग द्वारा कार्यान्वित किया जाता है, जिसका परिणाम 85 होगा, कुल अंक -

from sqlalchemy.sql import func
result = conn.execute(select([func.max(employee.c.marks)]))
print (result.fetchone())

इसी तरह, न्यूनतम () फ़ंक्शन जो 56, न्यूनतम अंक लौटाएगा, निम्नलिखित कोड द्वारा प्रदान किया जाएगा -

from sqlalchemy.sql import func
result = conn.execute(select([func.min(employee.c.marks)]))
print (result.fetchone())

तो, AVG () फ़ंक्शन को नीचे दिए गए कोड का उपयोग करके भी लागू किया जा सकता है -

from sqlalchemy.sql import func
result = conn.execute(select([func.avg(employee.c.marks)]))
print (result.fetchone())

Functions are normally used in the columns clause of a select statement. 
They can also be given label as well as a type. A label to function allows the result 
to be targeted in a result row based on a string name, and a type is required when 
you need result-set processing to occur.from sqlalchemy.sql import func

result = conn.execute(select([func.max(students.c.lastname).label('Name')]))

print (result.fetchone())

पिछले अध्याय में, हमने विभिन्न कार्यों जैसे कि अधिकतम (), मिनट (), गिनती (), आदि के बारे में सीखा है, यहाँ, हम सेट संचालन और उनके उपयोगों के बारे में जानेंगे।

UNION और INTERSECT जैसे सेट ऑपरेशन मानक SQL और इसकी अधिकांश बोली द्वारा समर्थित हैं। SQLAlchemy निम्नलिखित कार्यों की मदद से उन्हें लागू करता है -

संघ ()

दो या अधिक चयनित बयानों के परिणामों के संयोजन के दौरान, UNION परिणाम से डुप्लिकेट को समाप्त करता है। कॉलम और डेटाटाइप की संख्या दोनों तालिकाओं में समान होनी चाहिए।

संघ () फ़ंक्शन कई तालिकाओं से एक CompoundSelect ऑब्जेक्ट देता है। निम्नलिखित उदाहरण इसके उपयोग को दर्शाता है -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, union
engine = create_engine('sqlite:///college.db', echo = True)

meta = MetaData()
conn = engine.connect()
addresses = Table(
   'addresses', meta, 
   Column('id', Integer, primary_key = True), 
   Column('st_id', Integer), 
   Column('postal_add', String), 
   Column('email_add', String)
)

u = union(addresses.select().where(addresses.c.email_add.like('%@gmail.com addresses.select().where(addresses.c.email_add.like('%@yahoo.com'))))

result = conn.execute(u)
result.fetchall()

संघ एसक्यूएल अभिव्यक्ति के लिए अनुवाद का निर्माण करता है -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? UNION SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ?

हमारे पते तालिका से, निम्नलिखित पंक्तियाँ संघ संचालन का प्रतिनिधित्व करती हैं -

[
   (1, 1, 'Shivajinagar Pune', '[email protected]'),
   (2, 1, 'ChurchGate Mumbai', '[email protected]'),
   (3, 3, 'Jubilee Hills Hyderabad', '[email protected]'),
   (4, 5, 'MG Road Bangaluru', '[email protected]')
]

union_all ()

UNION सभी ऑपरेशन डुप्लिकेट को निकाल नहीं सकते और परिणाम में डेटा सॉर्ट नहीं कर सकते। उदाहरण के लिए, उपरोक्त क्वेरी में, UNION को प्रभाव देखने के लिए UNION ALL द्वारा प्रतिस्थापित किया जाता है।

u = union_all(addresses.select().where(addresses.c.email_add.like('%@gmail.com')), addresses.select().where(addresses.c.email_add.like('%@yahoo.com')))

इसी SQL अभिव्यक्ति निम्नानुसार है -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? UNION ALL SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ?

के सिवाय_()

एसक्यूएल EXCEPTक्लॉज / ऑपरेटर का उपयोग दो सेलेक्ट स्टेटमेंट्स को मिलाने और पहले सेलेक्ट स्टेटमेंट से पंक्तियों को वापस करने के लिए किया जाता है जो दूसरे सेलेक्ट स्टेटमेंट द्वारा वापस नहीं आते हैं। अपवाद_ () फ़ंक्शन EXCEPT क्लॉज़ के साथ एक SELECT अभिव्यक्ति उत्पन्न करता है।

निम्न उदाहरण में, अपवाद_ () फ़ंक्शन उन पते तालिका से केवल उन अभिलेखों को वापस करता है जिनके पास email_add फ़ील्ड में 'gmail.com' है, लेकिन उन लोगों को बाहर करता है जिनके पास post__dd फ़ील्ड के भाग के रूप में 'पुणे' है।

u = except_(addresses.select().where(addresses.c.email_add.like('%@gmail.com')), addresses.select().where(addresses.c.postal_add.like('%Pune')))

उपरोक्त कोड का परिणाम निम्नलिखित एसक्यूएल अभिव्यक्ति है -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? EXCEPT SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.postal_add LIKE ?

यह मानते हुए कि पते तालिका में पहले के उदाहरणों में उपयोग किया गया डेटा है, यह आउटपुट के बाद प्रदर्शित होगा -

[(2, 1, 'ChurchGate Mumbai', '[email protected]'),
   (3, 3, 'Jubilee Hills Hyderabad', '[email protected]')]

एक दूसरे को काटना ()

INTERSECT ऑपरेटर का उपयोग करते हुए, SQL दोनों SELECT स्टेटमेंट में से आम पंक्तियों को प्रदर्शित करता है। प्रतिच्छेदन () फ़ंक्शन इस व्यवहार को लागू करता है।

निम्नलिखित उदाहरणों में, दो SELECT कन्स्ट्रक्ट्स प्रतिच्छेद () फ़ंक्शन के पैरामीटर हैं। एक ईमेल_add कॉलम के हिस्से के रूप में 'gmail.com' वाली पंक्तियाँ देता है, और अन्य रिटर्न पंक्तियाँ जिनमें पोस्टल_एडीडी कॉलम का हिस्सा होता है। परिणाम दोनों परिणामों से सामान्य पंक्तियाँ होंगी।

u = intersect(addresses.select().where(addresses.c.email_add.like('%@gmail.com')), addresses.select().where(addresses.c.postal_add.like('%Pune')))

वास्तव में, यह SQL कथन का अनुसरण करने के बराबर है -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? INTERSECT SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.postal_add LIKE ?

नीचे दिए गए पते के अनुसार दो बाध्य पैरामीटर '% gmail.com' और '% पुणे' मूल डेटा से एकल पंक्ति उत्पन्न करते हैं -

[(1, 1, 'Shivajinagar Pune', '[email protected]')]

SQLAlchemy के ऑब्जेक्ट रिलेशनल मैपर एपीआई का मुख्य उद्देश्य उपयोगकर्ता-परिभाषित पायथन कक्षाओं को डेटाबेस तालिकाओं के साथ जोड़ना, और उन वर्गों की वस्तुओं को उनके संगत तालिकाओं में पंक्तियों के साथ सुविधाजनक बनाना है। वस्तुओं और पंक्तियों के राज्यों में परिवर्तन एक-दूसरे के साथ समान रूप से मेल खाते हैं। SQLAlchemy उपयोगकर्ता परिभाषित वर्गों और उनके परिभाषित संबंधों के संदर्भ में डेटाबेस क्वेरी को व्यक्त करने में सक्षम बनाता है।

ORM SQL अभिव्यक्ति भाषा के शीर्ष पर बनाया गया है। यह उपयोग का एक उच्च स्तरीय और अमूर्त पैटर्न है। वास्तव में, ORM अभिव्यक्ति भाषा का एक अनुप्रयुक्त उपयोग है।

हालाँकि, ऑब्जेक्ट रिलेशनल मैपर का उपयोग करके विशेष रूप से एक सफल एप्लिकेशन का निर्माण किया जा सकता है, कभी-कभी ओआरएम के साथ बनाया गया एप्लिकेशन सीधे अभिव्यक्ति भाषा का उपयोग कर सकता है जहां विशिष्ट डेटाबेस इंटरैक्शन की आवश्यकता होती है।

मैपिंग की घोषणा करें

सबसे पहले, create_engine () फ़ंक्शन को एक इंजन ऑब्जेक्ट सेट करने के लिए कहा जाता है जिसे बाद में SQL ऑपरेशन करने के लिए उपयोग किया जाता है। फ़ंक्शन के दो तर्क हैं, एक डेटाबेस का नाम है और दूसरा एक इको पैरामीटर है जब सेट ट्रू गतिविधि लॉग उत्पन्न करेगा। यदि यह मौजूद नहीं है, तो डेटाबेस बनाया जाएगा। निम्न उदाहरण में, एक SQLite डेटाबेस बनाया जाता है।

from sqlalchemy import create_engine
engine = create_engine('sqlite:///sales.db', echo = True)

इंजन डेटाबेस के लिए एक वास्तविक DBAPI कनेक्शन स्थापित करता है जब Engine.execute () या Engine.connect () जैसी विधि को बुलाया जाता है। इसके बाद SQLORM का उपयोग किया जाता है जो सीधे इंजन का उपयोग नहीं करता है; इसके बजाय, इसका उपयोग ORM द्वारा पर्दे के पीछे किया जाता है।

ORM के मामले में, कॉन्फ़िगरेशन प्रक्रिया डेटाबेस तालिकाओं का वर्णन करके और फिर उन कक्षाओं को परिभाषित करके शुरू होती है जिन्हें उन तालिकाओं में मैप किया जाएगा। SQLAlchemy में, ये दो कार्य एक साथ किए जाते हैं। यह घोषणा प्रणाली का उपयोग करके किया जाता है; बनाई गई कक्षाओं में उनके द्वारा मैप की गई वास्तविक डेटाबेस तालिका का वर्णन करने के लिए निर्देश शामिल हैं।

एक बेस क्लास, क्लासरूम के कैटालॉग और डिक्लेरेटिव सिस्टम में मैप्ड टेबल को स्टोर करता है। इसे डिक्लेरेटिव बेस क्लास कहा जाता है। आम तौर पर आयातित मॉड्यूल में इस आधार का केवल एक उदाहरण होगा। बेस क्लास बनाने के लिए घोषणात्मक_बेस () फ़ंक्शन का उपयोग किया जाता है। यह फ़ंक्शन sqlalchemy.ext.declarative मॉड्यूल में परिभाषित किया गया है।

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)

घोषणा में एक वर्ग होना चाहिए एक __tablename__ विशेषता, और कम से कम एक Columnजो एक प्राथमिक कुंजी का हिस्सा है। घोषणात्मक सभी को बदल देता हैColumn विशेष पायथन एक्सेसर्स वाली वस्तुएं जिन्हें जाना जाता है descriptors। इस प्रक्रिया को इंस्ट्रूमेंटेशन के रूप में जाना जाता है जो SQL संदर्भ में तालिका को संदर्भित करने का साधन प्रदान करता है और डेटाबेस से कॉलम के मूल्यों को बनाए रखने और लोड करने में सक्षम बनाता है।

सामान्य पायथन वर्ग की तरह इस मैप्ड क्लास में आवश्यकता के अनुसार विशेषताएँ और विधियाँ हैं।

घोषणा प्रणाली में वर्ग के बारे में जानकारी को टेबल मेटाडेटा कहा जाता है। SQLAlchemy घोषणा द्वारा बनाई गई एक विशिष्ट तालिका के लिए इस जानकारी का प्रतिनिधित्व करने के लिए टेबल ऑब्जेक्ट का उपयोग करता है। तालिका ऑब्जेक्ट विनिर्देशों के अनुसार बनाई गई है, और मैपर ऑब्जेक्ट का निर्माण करके वर्ग के साथ जुड़ा हुआ है। यह मैपर ऑब्जेक्ट सीधे उपयोग नहीं किया जाता है, लेकिन आंतरिक रूप से मैप्ड क्लास और टेबल के बीच इंटरफेस के रूप में उपयोग किया जाता है।

प्रत्येक टेबल ऑब्जेक्ट मेटाडाटा के रूप में जाना जाने वाले बड़े संग्रह का एक सदस्य है और यह ऑब्जेक्ट का उपयोग करके उपलब्ध है .metadataघोषणात्मक आधार वर्ग की विशेषता। MetaData.create_all()विधि है, डेटाबेस कनेक्टिविटी के स्रोत के रूप में हमारे इंजन में गुजरना। अभी तक नहीं बनाई गई सभी तालिकाओं के लिए, यह डेटाबेस के लिए रचनात्मक विवरण जारी करता है।

Base.metadata.create_all(engine)

डेटाबेस और तालिका बनाने के लिए पूरी स्क्रिप्ट, और पायथन क्लास को मैप करने के लिए नीचे दिया गया है -

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)
Base.metadata.create_all(engine)

जब निष्पादित किया जाता है, तो SQL अभिव्यक्ति निष्पादित होने के बाद पायथन कंसोल गूंज जाएगा -

CREATE TABLE customers (
   id INTEGER NOT NULL,
   name VARCHAR,
   address VARCHAR,
   email VARCHAR,
   PRIMARY KEY (id)
)

यदि हम SQLiteStudio ग्राफिक टूल का उपयोग करके Sales.db को खोलते हैं, तो यह उपर्युक्त संरचना के साथ इसके अंदर ग्राहकों की तालिका दिखाता है।

डेटाबेस के साथ बातचीत करने के लिए, हमें इसका हैंडल प्राप्त करने की आवश्यकता है। एक सत्र वस्तु डेटाबेस के लिए संभाल है। सत्र कक्षा को सत्रमेकर () का उपयोग करके परिभाषित किया गया है - एक विन्यास सत्र कारखाना विधि जो पहले बनाए गए इंजन ऑब्जेक्ट से जुड़ी है।

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)

सत्र ऑब्जेक्ट को उसके डिफ़ॉल्ट कंस्ट्रक्टर का उपयोग करके निम्न प्रकार से सेट किया जाता है -

session = Session()

सत्र वर्ग के कुछ आवश्यक तरीकों को नीचे सूचीबद्ध किया गया है -

अनु क्रमांक। विधि और विवरण
1

begin()

इस सत्र पर एक लेनदेन शुरू करता है

2

add()

सत्र में एक वस्तु रखता है। इसकी स्थिति अगले फ्लश ऑपरेशन पर डेटाबेस में बनी रहती है

3

add_all()

सत्र के लिए ऑब्जेक्ट का संग्रह जोड़ता है

4

commit()

सभी आइटम और किसी भी लेन-देन में प्रगति जारी है

5

delete()

हटाए गए के रूप में लेनदेन को चिह्नित करता है

6

execute()

SQL एक्सप्रेशन निष्पादित करता है

7

expire()

एक उदाहरण की तारीख से बाहर की विशेषताएँ

8

flush()

डेटाबेस के लिए सभी ऑब्जेक्ट परिवर्तन flushes

9

invalidate()

कनेक्शन अमान्य का उपयोग करके सत्र बंद कर देता है

10

rollback()

वर्तमान लेनदेन को प्रगति में वापस लाती है

1 1

close()

सभी मदों को समाप्त करके और प्रगति में किसी भी लेनदेन को समाप्त करके वर्तमान सत्र को बंद कर देता है

SQLAlchemy ORM के पिछले अध्यायों में, हमने सीखा है कि मैपिंग कैसे घोषित करें और सत्र बनाएं। इस अध्याय में, हम सीखेंगे कि टेबल पर वस्तुओं को कैसे जोड़ा जाए।

हमने ग्राहक वर्ग घोषित किया है जिसे ग्राहकों की तालिका में मैप किया गया है। हमें इस वर्ग की एक वस्तु की घोषणा करनी है और इसे सत्र वस्तु के जोड़ () विधि द्वारा लगातार तालिका में जोड़ना है।

c1 = Sales(name = 'Ravi Kumar', address = 'Station Road Nanded', email = '[email protected]')
session.add(c1)

ध्यान दें कि यह लेन-देन तब तक लंबित है जब तक कि कमिट () विधि का उपयोग करके इसे वापस नहीं किया जाता है।

session.commit()

ग्राहकों की तालिका में रिकॉर्ड जोड़ने के लिए पूरी स्क्रिप्ट निम्नलिखित है -

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

c1 = Customers(name = 'Ravi Kumar', address = 'Station Road Nanded', email = '[email protected]')

session.add(c1)
session.commit()

कई रिकॉर्ड जोड़ने के लिए, हम उपयोग कर सकते हैं add_all() सत्र वर्ग की विधि।

session.add_all([
   Customers(name = 'Komal Pande', address = 'Koti, Hyderabad', email = '[email protected]'), 
   Customers(name = 'Rajender Nath', address = 'Sector 40, Gurgaon', email = '[email protected]'), 
   Customers(name = 'S.M.Krishna', address = 'Budhwar Peth, Pune', email = '[email protected]')]
)

session.commit()

SQLiteStudio का तालिका दृश्य दिखाता है कि ग्राहक तालिका में रिकॉर्ड लगातार जोड़े जाते हैं। निम्नलिखित छवि परिणाम दिखाती है -

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

यह डेटाबेस में इस क्वेरी द्वारा मेल की गई बल्क अपडेट क्वेरी और अपडेट पंक्तियों को निष्पादित करता है।

इस अध्याय में, हम देखेंगे कि वांछित मानों के साथ तालिका को कैसे संशोधित या अद्यतन किया जाए।

किसी भी वस्तु की एक निश्चित विशेषता के डेटा को संशोधित करने के लिए, हमें उसे नया मान असाइन करना होगा और परिवर्तन को स्थायी बनाने के लिए परिवर्तनों को प्रतिबद्ध करना होगा।

आइए उस तालिका से एक वस्तु प्राप्त करें जिसकी प्राथमिक कुंजी पहचानकर्ता, ID = 2 के साथ हमारे ग्राहक तालिका में है। हम सत्र की विधि () का उपयोग इस प्रकार कर सकते हैं -

x = session.query(Customers).get(2)

हम नीचे दिए गए कोड के साथ चयनित वस्तु की सामग्री प्रदर्शित कर सकते हैं -

print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)

हमारे ग्राहकों की तालिका से, निम्न आउटपुट प्रदर्शित होना चाहिए -

Name: Komal Pande Address: Koti, Hyderabad Email: [email protected]

अब हमें नीचे दिए गए अनुसार नए मान निर्दिष्ट करके पता फ़ील्ड अपडेट करना होगा -

x.address = 'Banjara Hills Secunderabad'
session.commit()

परिवर्तन लगातार डेटाबेस में परिलक्षित होगा। अब हम तालिका में पहली पंक्ति के उपयोग से संबंधित वस्तु लाते हैंfirst() method निम्नानुसार है -

x = session.query(Customers).first()

यह SQL एक्सप्रेशन के बाद निष्पादित होगा -

SELECT customers.id 
AS customers_id, customers.name 
AS customers_name, customers.address 
AS customers_address, customers.email 
AS customers_email
FROM customers
LIMIT ? OFFSET ?

बाउंड पैरामीटर क्रमशः LIMIT = 1 और OFFSET = 0 होंगे, जिसका अर्थ है कि पहली पंक्ति का चयन किया जाएगा।

print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)

अब, पहली पंक्ति प्रदर्शित करने वाले उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -

Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]

अब नाम विशेषता बदलें और नीचे दिए गए कोड का उपयोग करके सामग्री प्रदर्शित करें -

x.name = 'Ravi Shrivastava'
print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)

उपरोक्त कोड का आउटपुट है -

Name: Ravi Shrivastava Address: Station Road Nanded Email: [email protected]

भले ही परिवर्तन प्रदर्शित हो, लेकिन यह प्रतिबद्ध नहीं है। आप का उपयोग करके पहले की लगातार स्थिति बनाए रख सकते हैंrollback() method नीचे दिए गए कोड के साथ।

session.rollback()

print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)

पहले रिकॉर्ड की मूल सामग्री प्रदर्शित की जाएगी।

बल्क अपडेट के लिए, हम क्वेरी ऑब्जेक्ट के अपडेट () पद्धति का उपयोग करेंगे। आइए हम कोशिश करते हैं और एक उपसर्ग देते हैं, 'मि।' प्रत्येक पंक्ति में नाम के लिए (आईडी = 2 को छोड़कर)। इसी अद्यतन () बयान इस प्रकार है -

session.query(Customers).filter(Customers.id! = 2).
update({Customers.name:"Mr."+Customers.name}, synchronize_session = False)

The update() method requires two parameters as follows −

  • कुंजी के मूल्यों का एक शब्दकोश, जिसे अद्यतन किए जाने की विशेषता है, और विशेषता की नई सामग्री होने का महत्व है।

  • सत्र में विशेषताएँ अद्यतन करने के लिए रणनीति का उल्लेख करते हुए सिंक्रोनाइज़_ सत्र विशेषता। मान्य मान गलत हैं: सत्र को सिंक्रनाइज़ नहीं करने के लिए, लाने: अद्यतन क्वेरी से मेल खाने वाली वस्तुओं को खोजने के लिए अद्यतन से पहले एक चुनिंदा क्वेरी करता है; और मूल्यांकन: सत्र में वस्तुओं पर मानदंड का मूल्यांकन करें।

तालिका में 4 में से तीन पंक्तियों में 'मि' के साथ उपसर्ग नाम होगा। हालाँकि, परिवर्तन प्रतिबद्ध नहीं हैं और इसलिए यह SQLiteStudio के तालिका दृश्य में परिलक्षित नहीं होगा। जब हम सत्र करेंगे तब ही इसे रीफ्रेश किया जाएगा।

इस अध्याय में, हम चर्चा करेंगे कि कैसे फ़िल्टर लागू करें और उनके कोड के साथ कुछ निश्चित फ़िल्टर संचालन भी करें।

फ़िल्टर ऑब्जेक्ट () विधि का उपयोग करके क्वेरी ऑब्जेक्ट द्वारा दर्शाए गए परिणाम को कुछ मानदंडों के अधीन किया जा सकता है। फिल्टर विधि का सामान्य उपयोग इस प्रकार है -

session.query(class).filter(criteria)

निम्नलिखित उदाहरण में, ग्राहक तालिका पर SELECT क्वेरी द्वारा प्राप्त परिणाम एक शर्त द्वारा फ़िल्टर किया गया है, (ID> 2) -

result = session.query(Customers).filter(Customers.id>2)

यह कथन निम्नलिखित एसक्यूएल अभिव्यक्ति में अनुवाद करेगा -

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.id > ?

चूंकि बाध्य पैरामीटर () को 2 के रूप में दिया गया है, केवल उन पंक्तियों को आईडी कॉलम> 2 के साथ प्रदर्शित किया जाएगा। पूरा कोड नीचे दिया गया है -

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).filter(Customers.id>2)

for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

पायथन कंसोल में प्रदर्शित आउटपुट निम्नानुसार है -

ID: 3 Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]
ID: 4 Name: S.M.Krishna Address: Budhwar Peth, Pune Email: [email protected]

अब, हम उनके संबंधित कोड और आउटपुट के साथ फ़िल्टर संचालन सीखेंगे।

बराबर

प्रयुक्त सामान्य ऑपरेटर == है और यह समानता की जांच करने के लिए मापदंड लागू करता है।

result = session.query(Customers).filter(Customers.id == 2)

for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

SQLAlchemy 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.id = ?

उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -

ID: 2 Name: Komal Pande Address: Banjara Hills Secunderabad Email: [email protected]

न के बराबर

बराबर नहीं के लिए उपयोग किया जाने वाला ऑपरेटर! = है और यह समान मापदंड प्रदान नहीं करता है।

result = session.query(Customers).filter(Customers.id! = 2)

for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

परिणामी 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.id != ?

कोड की उपरोक्त लाइनों के लिए आउटपुट निम्नानुसार है -

ID: 1 Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
ID: 3 Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]
ID: 4 Name: S.M.Krishna Address: Budhwar Peth, Pune Email: [email protected]

पसंद

जैसे () विधि ही सेलेक्ट एक्सप्रेशन में WHERE क्लॉज के लिए LIKE मानदंड बनाती है।

result = session.query(Customers).filter(Customers.name.like('Ra%'))
for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

SQLAlchemy कोड के ऊपर 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 LIKE ?

और उपरोक्त कोड के लिए आउटपुट है -

ID: 1 Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
ID: 3 Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]

में

यह ऑपरेटर यह जाँचता है कि सूची में आइटम का संग्रह करने के लिए स्तंभ मान है या नहीं। यह in_ () विधि द्वारा प्रदान किया गया है।

result = session.query(Customers).filter(Customers.id.in_([1,3]))
for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

यहाँ, SQLite इंजन द्वारा मूल्यांकन की गई 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.id IN (?, ?)

उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -

ID: 1 Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
ID: 3 Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]

तथा

यह संयुग्मन या तो उत्पन्न होता है putting multiple commas separated criteria in the filter or using and_() method जैसा कि नीचे दिया गया है -

result = session.query(Customers).filter(Customers.id>2, Customers.name.like('Ra%'))
for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

from sqlalchemy import and_
result = session.query(Customers).filter(and_(Customers.id>2, Customers.name.like('Ra%')))

for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

उपरोक्त दोनों दृष्टिकोण समान 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.id > ? AND customers.name LIKE ?

कोड की उपरोक्त लाइनों के लिए आउटपुट है -

ID: 3 Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]

या

इस संयोजन द्वारा कार्यान्वित किया जाता है or_() method

from sqlalchemy import or_
result = session.query(Customers).filter(or_(Customers.id>2, Customers.name.like('Ra%')))

for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

नतीजतन, SQLite इंजन के बराबर 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.id > ? OR customers.name LIKE ?

उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -

ID: 1 Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
ID: 3 Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]
ID: 4 Name: S.M.Krishna Address: Budhwar Peth, Pune Email: [email protected]

क्वेरी ऑब्जेक्ट की कई विधियाँ हैं जो तुरंत SQL जारी करती हैं और लोड किए गए डेटाबेस परिणामों से युक्त मान लौटाती हैं।

यहां सूची और स्केलर का संक्षिप्त विवरण दिया गया है -

सब()

यह एक सूची देता है। नीचे दिए गए सभी () फ़ंक्शन के लिए कोड की पंक्ति है।

session.query(Customers).all()

पायथन कंसोल, SQL अभिव्यक्ति के उत्सर्जित होने के बाद प्रदर्शित होता है -

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

प्रथम()

यह एक की सीमा लागू करता है और स्केलर के रूप में पहला परिणाम देता है।

SELECT customers.id 
AS customers_id, customers.name 
AS customers_name, customers.address 
AS customers_address, customers.email 
AS customers_email
FROM customers
LIMIT ? OFFSET ?

लिमिट के लिए बाध्य पैरामीटर 1 है और OFFSET के लिए 0 है।

एक()

यह कमांड पूरी तरह से सभी पंक्तियों को प्राप्त करता है, और यदि परिणाम में मौजूद एक वस्तु पहचान या समग्र पंक्ति नहीं है, तो यह एक त्रुटि उठाता है।

session.query(Customers).one()

कई पंक्तियों के साथ -

MultipleResultsFound: Multiple rows were found for one()

कोई पंक्तियाँ नहीं मिलीं -

NoResultFound: No row was found for one()

एक () विधि उन प्रणालियों के लिए उपयोगी है जो "अलग-अलग आइटम" "कोई आइटम नहीं मिला" बनाम "अलग-अलग आइटम" को संभालने की उम्मीद करते हैं।

अदिश ()

यह एक () विधि का आह्वान करता है, और सफलता के बाद पंक्ति का पहला कॉलम निम्नानुसार लौटता है -

session.query(Customers).filter(Customers.id == 3).scalar()

यह 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.id = ?

इससे पहले, पाठ () फ़ंक्शन का उपयोग करते हुए शाब्दिक 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

इस सत्र में एक अन्य तालिका के निर्माण का वर्णन किया गया है जो हमारे डेटाबेस में पहले से मौजूद है। ग्राहकों की तालिका में ग्राहकों का मास्टर डेटा होता है। अब हमें इनवॉयस टेबल बनाने की आवश्यकता है जिसमें किसी भी ग्राहक के चालान की संख्या हो सकती है। यह एक से कई रिश्तों का मामला है।

घोषणात्मक का उपयोग करते हुए, हम इस तालिका को इसके मैप किए गए वर्ग के साथ परिभाषित करते हैं, नीचे दिए गए अनुसार चालान -

from sqlalchemy import create_engine, ForeignKey, Column, Integer, String
engine = create_engine('sqlite:///sales.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
from sqlalchemy.orm import relationship

class Customer(Base):
   __tablename__ = 'customers'

   id = Column(Integer, primary_key = True)
   name = Column(String)
   address = Column(String)
   email = Column(String)

class Invoice(Base):
   __tablename__ = 'invoices'
   
   id = Column(Integer, primary_key = True)
   custid = Column(Integer, ForeignKey('customers.id'))
   invno = Column(Integer)
   amount = Column(Integer)
   customer = relationship("Customer", back_populates = "invoices")

Customer.invoices = relationship("Invoice", order_by = Invoice.id, back_populates = "customer")
Base.metadata.create_all(engine)

यह नीचे के रूप में SQLite इंजन के लिए एक सृजन तालिका क्वेरी भेजेगा -

CREATE TABLE invoices (
   id INTEGER NOT NULL,
   custid INTEGER,
   invno INTEGER,
   amount INTEGER,
   PRIMARY KEY (id),
   FOREIGN KEY(custid) REFERENCES customers (id)
)

हम जाँच सकते हैं कि SQLiteStudio टूल की सहायता से Sales.db में नई तालिका बनाई गई है।

इनवॉइस क्लास कस्टर्ड एट्रिब्यूट पर फॉरेनके कंस्ट्रक्शन लागू करती है। यह निर्देश बताता है कि इस कॉलम में मान ग्राहकों की तालिका में आईडी कॉलम में मौजूद मानों के लिए विवश होना चाहिए। यह संबंधपरक डेटाबेस की एक मुख्य विशेषता है, और "गोंद" है जो समृद्ध अतिव्यापी संबंधों के लिए तालिकाओं के असंबद्ध संग्रह को बदल देता है।

एक दूसरा निर्देश, जिसे संबंध के रूप में जाना जाता है (), ORM को बताता है कि इनवॉइस क्लास को विशेषता इनवॉइस कस्टमाइज़र का उपयोग करके ग्राहक वर्ग से जोड़ा जाना चाहिए। संबंध () इस संबंध की प्रकृति का निर्धारण करने के लिए दो तालिकाओं के बीच विदेशी कुंजी संबंधों का उपयोग करता है, यह निर्धारित करते हुए कि यह कई से एक है।

एक अतिरिक्त संबंध () निर्देश ग्राहक मैप्ड क्लास पर विशेषता Customer.invoices के तहत रखा गया है। पैरामीटर रिलेशनशिप.बैक_पॉप्स को पूरक विशेषता नामों के संदर्भ में सौंपा गया है, ताकि प्रत्येक संबंध () रिवर्स में व्यक्त किए गए उसी संबंध के बारे में बुद्धिमान निर्णय ले सके। एक तरफ, Invoices.customer चालान उदाहरणों को संदर्भित करता है, और दूसरी तरफ, Customer.invoices ग्राहक उदाहरणों की एक सूची को संदर्भित करता है।

संबंध फ़ंक्शन SQLAlchemy ORM पैकेज के रिलेशनशिप API का एक हिस्सा है। यह दो मैप किए गए वर्गों के बीच एक संबंध प्रदान करता है। यह एक अभिभावक-बच्चे या सहयोगी तालिका संबंध से मेल खाता है।

निम्नलिखित बुनियादी संबंध पैटर्न पाए जाते हैं -

अनेको के लिये एक

एक से कई संबंध बच्चे की मेज पर एक विदेशी कुंजी की मदद से माता-पिता को संदर्भित करते हैं। संबंध () तब माता-पिता पर निर्दिष्ट किया जाता है, जैसा कि बच्चे द्वारा प्रस्तुत वस्तुओं के संग्रह को संदर्भित करता है। रिलेशनशिप.बैक_पॉप्लेट्स पैरामीटर को एक-से-कई में एक द्विदिश संबंध स्थापित करने के लिए उपयोग किया जाता है, जहां "रिवर्स" पक्ष कई से एक है।

एक करने के लिए कई

दूसरी ओर, कई टू वन रिलेशनशिप बच्चे को संदर्भित करने के लिए पेरेंट टेबल में एक विदेशी कुंजी लगाते हैं। संबंध () को माता-पिता पर घोषित किया जाता है, जहां एक नई स्केलर-होल्डिंग विशेषता बनाई जाएगी। यहाँ फिर से relationship.back_populates पैरामीटर का उपयोग बिडायरेनिअलबेहेवियर के लिए किया जाता है।

एक से एक

वन टू वन रिलेशनशिप अनिवार्य रूप से प्रकृति में एक द्विदिश संबंध है। Uselist ध्वज रिश्ते के "कई" पक्ष पर एक संग्रह के बजाय एक स्केलर विशेषता के स्थान को इंगित करता है। एक-से-एक को एक-से-एक प्रकार के संबंध में बदलने के लिए, uselist पैरामीटर को असत्य पर सेट करें।

कई कई

कई से कई संबंध उनकी विदेशी चाबियों के साथ विशेषताओं को परिभाषित करके दो वर्गों से संबंधित एक संघ तालिका को जोड़कर स्थापित किया जाता है। यह संबंध के माध्यमिक तर्क द्वारा इंगित किया गया है ()। आमतौर पर, तालिका घोषणात्मक आधार वर्ग के साथ जुड़ी मेटाडेटा ऑब्जेक्ट का उपयोग करती है, ताकि फॉरेनके के निर्देश दूरस्थ तालिकाओं का पता लगा सकें जिनके साथ लिंक करना है। प्रत्येक रिश्ते के लिए रिलेशनशिप .बैक_पोपलेट्स पैरामीटर () एक द्विदिश संबंध स्थापित करता है। रिश्ते के दोनों पक्षों में एक संग्रह होता है।

इस अध्याय में, हम 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()

अब जबकि हमारे पास दो टेबल हैं, हम देखेंगे कि एक ही समय में दोनों टेबलों पर क्वेरी कैसे बनाई जाए। ग्राहक और चालान के बीच एक सरल निहित जुड़ाव का निर्माण करने के लिए, हम उनके संबंधित कॉलम को समान करने के लिए Query.filter () का उपयोग कर सकते हैं। नीचे, हम इस पद्धति का उपयोग करते हुए ग्राहक और इनवॉइस संस्थाओं को लोड करते हैं -

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()

for c, i in session.query(Customer, Invoice).filter(Customer.id == Invoice.custid).all():
   print ("ID: {} Name: {} Invoice No: {} Amount: {}".format(c.id,c.name, i.invno, i.amount))

SQLAlchemy द्वारा उत्सर्जित SQL अभिव्यक्ति निम्नानुसार है -

SELECT customers.id 
AS customers_id, customers.name 
AS customers_name, customers.address 
AS customers_address, customers.email 
AS customers_email, invoices.id 
AS invoices_id, invoices.custid 
AS invoices_custid, invoices.invno 
AS invoices_invno, invoices.amount 
AS invoices_amount
FROM customers, invoices
WHERE customers.id = invoices.custid

और कोड की उपरोक्त पंक्तियों का परिणाम निम्नानुसार है -

ID: 2 Name: Gopal Krishna Invoice No: 10 Amount: 15000
ID: 2 Name: Gopal Krishna Invoice No: 14 Amount: 3850
ID: 3 Name: Govind Pant Invoice No: 3 Amount: 10000
ID: 3 Name: Govind Pant Invoice No: 4 Amount: 5000
ID: 4 Name: Govind Kala Invoice No: 7 Amount: 12000
ID: 4 Name: Govind Kala Invoice No: 8 Amount: 8500
ID: 5 Name: Abdul Rahman Invoice No: 9 Amount: 15000
ID: 5 Name: Abdul Rahman Invoice No: 11 Amount: 6000

वास्तविक SQL JOIN सिंटैक्स को Query.join () विधि का उपयोग करके आसानी से प्राप्त किया जाता है -

session.query(Customer).join(Invoice).filter(Invoice.amount == 8500).all()

शामिल होने के लिए एसक्यूएल अभिव्यक्ति कंसोल पर प्रदर्शित किया जाएगा -

SELECT customers.id 
AS customers_id, customers.name 
AS customers_name, customers.address 
AS customers_address, customers.email 
AS customers_email
FROM customers JOIN invoices ON customers.id = invoices.custid
WHERE invoices.amount = ?

हम परिणाम को लूप के लिए उपयोग कर सकते हैं -

result = session.query(Customer).join(Invoice).filter(Invoice.amount == 8500)
for row in result:
   for inv in row.invoices:
      print (row.id, row.name, inv.invno, inv.amount)

बाइंड पैरामीटर के रूप में 8500 के साथ, निम्नलिखित आउटपुट प्रदर्शित होता है -

4 Govind Kala 8 8500

Query.join () जानता है कि इन तालिकाओं के बीच कैसे जुड़ना है क्योंकि उनके बीच केवल एक ही विदेशी कुंजी है। यदि कोई विदेशी कुंजियाँ नहीं थीं, या अधिक विदेशी कुंजियाँ नहीं थीं, तो Query.join () बेहतर काम करता है जब निम्नलिखित रूपों में से एक का उपयोग किया जाता है -

query.join (चालान, आईडी == Address.custid) स्पष्ट स्थिति
query.join (Customer.invoices) बाएं से दाएं संबंध निर्दिष्ट करें
query.join (चालान, Customer.invoices) वही, स्पष्ट लक्ष्य के साथ
query.join ( 'चालान') एक ही, एक स्ट्रिंग का उपयोग कर

इसी प्रकार, बाहरी बाहरी जुड़ाव को प्राप्त करने के लिए आउटरजोइन () फ़ंक्शन उपलब्ध है।

query.outerjoin(Customer.invoices)

सबक्वेरी () पद्धति एक SQL अभिव्यक्ति का चयन करती है जो उपनाम के भीतर चयनित चयन कथन का प्रतिनिधित्व करती है।

from sqlalchemy.sql import func

stmt = session.query(
   Invoice.custid, func.count('*').label('invoice_count')
).group_by(Invoice.custid).subquery()

Stmt ऑब्जेक्ट में नीचे SQL विवरण होगा -

SELECT invoices.custid, count(:count_1) AS invoice_count FROM invoices GROUP BY invoices.custid

एक बार जब हम अपना बयान देते हैं, तो यह एक टेबल निर्माण की तरह व्यवहार करता है। कथन पर कॉलम एक विशेषता के माध्यम से पहुँचा जा सकता है जिसे c कहा जाता है जैसा कि नीचे दिए गए कोड में दिखाया गया है -

for u, count in session.query(Customer, stmt.c.invoice_count).outerjoin(stmt, Customer.id == stmt.c.custid).order_by(Customer.id):
   print(u.name, count)

लूप के लिए उपरोक्त चालान की नाम-वार गिनती प्रदर्शित करता है -

Arjun Pandit None
Gopal Krishna 2
Govind Pant 2
Govind Kala 2
Abdul Rahman 2

इस अध्याय में, हम उन ऑपरेटरों के बारे में चर्चा करेंगे जो रिश्तों पर निर्माण करते हैं।

__eq __ ()

उपरोक्त ऑपरेटर कई-से-एक "बराबर" तुलना है। इस ऑपरेटर के लिए कोड की रेखा नीचे दी गई है -

s = session.query(Customer).filter(Invoice.invno.__eq__(12))

कोड की उपरोक्त पंक्ति के लिए समकक्ष SQL क्वेरी है -

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

__ne __ ()

यह ऑपरेटर कई-से-एक "तुलना नहीं" के बराबर है। इस ऑपरेटर के लिए कोड की रेखा नीचे दी गई है -

s = session.query(Customer).filter(Invoice.custid.__ne__(2))

कोड की उपरोक्त पंक्ति के लिए समकक्ष SQL क्वेरी नीचे दी गई है -

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

शामिल ()

यह ऑपरेटर एक-से-कई संग्रहों के लिए उपयोग किया जाता है और नीचे दिए गए कोड में शामिल है () -

s = session.query(Invoice).filter(Invoice.invno.contains([3,4,5]))

कोड की उपरोक्त पंक्ति के लिए समकक्ष SQL क्वेरी है -

SELECT invoices.id 
AS invoices_id, invoices.custid 
AS invoices_custid, invoices.invno 
AS invoices_invno, invoices.amount 
AS invoices_amount
FROM invoices
WHERE (invoices.invno LIKE '%' + ? || '%')

कोई भी()

किसी भी () ऑपरेटर का उपयोग संग्रह के लिए किया जाता है जैसा कि नीचे दिखाया गया है -

s = session.query(Customer).filter(Customer.invoices.any(Invoice.invno==11))

कोड की उपरोक्त लाइन के लिए समकक्ष 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 EXISTS (
   SELECT 1
   FROM invoices
   WHERE customers.id = invoices.custid 
   AND invoices.invno = ?)

(है)

इस ऑपरेटर का उपयोग स्केलर संदर्भों के लिए किया जाता है -

s = session.query(Invoice).filter(Invoice.customer.has(name = 'Arjun Pandit'))

कोड की उपरोक्त पंक्ति के लिए समकक्ष SQL क्वेरी है -

SELECT invoices.id 
AS invoices_id, invoices.custid 
AS invoices_custid, invoices.invno 
AS invoices_invno, invoices.amount 
AS invoices_amount
FROM invoices
WHERE EXISTS (
   SELECT 1
   FROM customers
   WHERE customers.id = invoices.custid 
   AND customers.name = ?)

उत्सुक भार प्रश्नों की संख्या को कम करता है। 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 का परिणाम दो पंक्तियों में है, लेकिन यह ग्राहक को एक उदाहरण देता है। इसका कारण यह है कि क्वेरी एक "विशिष्ट" रणनीति लागू करती है, वस्तु पहचान के आधार पर, लौटी संस्थाओं को। शामिल किए गए उत्सुक लोडिंग को क्वेरी परिणामों को प्रभावित किए बिना लागू किया जा सकता है।

सब-लोड लोड () संबंधित भार को लोड करने के लिए अधिक उपयुक्त है, जबकि जुड़ाव () कई-से-एक संबंध के लिए बेहतर अनुकूल है।

एक ही टेबल पर डिलीट ऑपरेशन करना आसान है। आपको बस इतना करना है कि एक सत्र से मैप की गई कक्षा की एक वस्तु को हटा दें और कार्रवाई करें। हालाँकि, कई संबंधित तालिकाओं पर कार्रवाई को थोड़ा मुश्किल है।

हमारे Sales.db डेटाबेस में, ग्राहक और इनवॉइस क्लासेस को ग्राहक के साथ मैप किया जाता है और एक से कई प्रकार के संबंधों के साथ इनवॉइस टेबल दिया जाता है। हम ग्राहक ऑब्जेक्ट को हटाने और परिणाम देखने का प्रयास करेंगे।

एक त्वरित संदर्भ के रूप में, ग्राहक और चालान कक्षाओं की परिभाषाएँ नीचे दी गई हैं -

from sqlalchemy import create_engine, ForeignKey, Column, Integer, String
engine = create_engine('sqlite:///sales.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
from sqlalchemy.orm import relationship
class Customer(Base):
   __tablename__ = 'customers'

   id = Column(Integer, primary_key = True)
   name = Column(String)
   address = Column(String)
   email = Column(String)
   
class Invoice(Base):
   __tablename__ = 'invoices'

   id = Column(Integer, primary_key = True)
   custid = Column(Integer, ForeignKey('customers.id'))
   invno = Column(Integer)
   amount = Column(Integer)
   customer = relationship("Customer", back_populates = "invoices")
   
Customer.invoices = relationship("Invoice", order_by = Invoice.id, back_populates = "customer")

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

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
session = Session()
x = session.query(Customer).get(2)

हमारी नमूना तालिका में, x.name 'गोपाल कृष्ण' होता है। आइए हम इस x को सत्र से हटाते हैं और इस नाम की घटना को गिनते हैं।

session.delete(x)
session.query(Customer).filter_by(name = 'Gopal Krishna').count()

परिणामस्वरूप SQL एक्सप्रेशन 0 पर वापस आ जाएगा।

SELECT count(*) 
AS count_1
FROM (
   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 = ?) 
AS anon_1('Gopal Krishna',) 0

हालाँकि, x के संबंधित इनवॉइस ऑब्जेक्ट अभी भी हैं। यह निम्नलिखित कोड द्वारा सत्यापित किया जा सकता है -

session.query(Invoice).filter(Invoice.invno.in_([10,14])).count()

यहां 10 और 14 ग्राहक गोपाल कृष्ण के चालान नंबर हैं। उपरोक्त क्वेरी का परिणाम 2 है, जिसका अर्थ है कि संबंधित ऑब्जेक्ट हटाए नहीं गए हैं।

SELECT count(*) 
AS count_1
FROM (
   SELECT invoices.id 
   AS invoices_id, invoices.custid 
   AS invoices_custid, invoices.invno 
   AS invoices_invno, invoices.amount 
   AS invoices_amount
   FROM invoices
   WHERE invoices.invno IN (?, ?)) 
AS anon_1(10, 14) 2

इसका कारण यह है कि SQLAlchemy कैस्केड के विलोपन को ग्रहण नहीं करता है; हमें इसे हटाने के लिए एक कमांड देनी होगी।

व्यवहार को बदलने के लिए, हम User.addresses संबंध पर कैस्केड विकल्प कॉन्फ़िगर करते हैं। चल रहे सत्र को बंद करते हैं, नए ऐक्सटेटिव_बेस () का उपयोग करते हैं और उपयोगकर्ता वर्ग को फिर से परिभाषित करते हैं, कैस्केड कॉन्फ़िगरेशन सहित एड्रेस रिलेशनशिप में जोड़ते हैं।

संबंध समारोह में कैस्केड विशेषता कैस्केड नियमों की अल्पविराम द्वारा अलग की गई सूची है जो यह निर्धारित करती है कि माता-पिता से बच्चे तक सत्र संचालन कैसे "कैस्केड" किया जाना चाहिए। डिफ़ॉल्ट रूप से, यह गलत है, जिसका अर्थ है कि यह "सेव-अपडेट, मर्ज" है।

उपलब्ध कैस्केड इस प्रकार हैं -

  • save-update
  • merge
  • expunge
  • delete
  • delete-orphan
  • refresh-expire

अक्सर उपयोग किया जाने वाला विकल्प "सभी, हटाना-अनाथ" है यह इंगित करने के लिए कि संबंधित वस्तुएं सभी मामलों में मूल वस्तु के साथ पालन करें, और डी-संबद्ध होने पर हटा दी जाएं।

इसलिए redeclared ग्राहक वर्ग नीचे दिखाया गया है -

class Customer(Base): 
   __tablename__ = 'customers'
   
   id = Column(Integer, primary_key = True) 
   name = Column(String) 
   address = Column(String) 
   email = Column(String) 
   invoices = relationship(
      "Invoice", 
      order_by = Invoice.id, 
      back_populates = "customer",
      cascade = "all, 
      delete, delete-orphan" 
   )

हम नीचे दिए गए प्रोग्राम का उपयोग करके ग्राहक को गोपाल कृष्ण नाम से हटाते हैं और इसके संबंधित इनवॉइस ऑब्जेक्ट्स की गिनती देखते हैं -

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()
x = session.query(Customer).get(2)
session.delete(x)
session.query(Customer).filter_by(name = 'Gopal Krishna').count()
session.query(Invoice).filter(Invoice.invno.in_([10,14])).count()

गिनती अब 0 से ऊपर स्क्रिप्ट द्वारा उत्सर्जित एसक्यूएल के साथ है -

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.id = ?
(2,)
SELECT invoices.id 
AS invoices_id, invoices.custid 
AS invoices_custid, invoices.invno 
AS invoices_invno, invoices.amount
AS invoices_amount
FROM invoices
WHERE ? = invoices.custid 
ORDER BY invoices.id (2,)
DELETE FROM invoices 
WHERE invoices.id = ? ((1,), (2,))
DELETE FROM customers 
WHERE customers.id = ? (2,)
SELECT count(*) 
AS count_1
FROM (
   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 = ?) 
AS anon_1('Gopal Krishna',)
SELECT count(*) 
AS count_1
FROM (
   SELECT invoices.id 
   AS invoices_id, invoices.custid 
   AS invoices_custid, invoices.invno 
   AS invoices_invno, invoices.amount 
   AS invoices_amount
   FROM invoices
   WHERE invoices.invno IN (?, ?)) 
AS anon_1(10, 14)
0

Many to Many relationshipदो तालिकाओं के बीच एक संघ तालिका जोड़कर हासिल की जाती है, जैसे कि इसमें दो विदेशी कुंजियाँ हों - प्रत्येक तालिका की प्राथमिक कुंजी से एक। इसके अलावा, दो तालिकाओं की मैपिंग करने वाली कक्षाओं में एक विशेषता होती है, जिसे संबंध की माध्यमिक विशेषता () फ़ंक्शन के रूप में सौंपी गई अन्य एसोसिएशन तालिकाओं की वस्तुओं के संग्रह के साथ होती है।

इस प्रयोजन के लिए, हम दो तालिकाओं - विभाग और कर्मचारी के साथ एक SQLite डेटाबेस (mycollege.db) बनाएंगे। यहां, हम मानते हैं कि एक कर्मचारी एक से अधिक विभागों का एक हिस्सा है, और एक विभाग में एक से अधिक कर्मचारी हैं। यह कई-से-कई संबंधों का गठन करता है।

कर्मचारी और विभाग की कक्षाओं की परिभाषा विभाग और कर्मचारी की तालिका में निम्नानुसार है -

from sqlalchemy import create_engine, ForeignKey, Column, Integer, String
engine = create_engine('sqlite:///mycollege.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
from sqlalchemy.orm import relationship

class Department(Base):
   __tablename__ = 'department'
   id = Column(Integer, primary_key = True)
   name = Column(String)
   employees = relationship('Employee', secondary = 'link')
   
class Employee(Base):
   __tablename__ = 'employee'
   id = Column(Integer, primary_key = True)
   name = Column(String)
   departments = relationship(Department,secondary='link')

अब हम एक लिंक क्लास को परिभाषित करते हैं। यह लिंक टेबल से जुड़ा हुआ है और इसमें विभाग और कर्मचारी तालिका की प्राथमिक कुंजियों का संदर्भ देते हुए क्रमशः विभाग_आईडी और कर्मचारी_ सहायता विशेषताएँ सम्‍मिलित हैं।

class Link(Base):
   __tablename__ = 'link'
   department_id = Column(
      Integer, 
      ForeignKey('department.id'), 
      primary_key = True)

employee_id = Column(
   Integer, 
   ForeignKey('employee.id'), 
   primary_key = True)

यहां, हमें यह नोट करना होगा कि विभाग वर्ग में कर्मचारी वर्ग से संबंधित कर्मचारी विशेषता है। संबंध फ़ंक्शन की द्वितीयक विशेषता को उसके मान के रूप में एक लिंक सौंपा गया है।

इसी प्रकार, कर्मचारी वर्ग में विभाग वर्ग से संबंधित विभाग विशेषता है। संबंध फ़ंक्शन की द्वितीयक विशेषता को उसके मान के रूप में एक लिंक सौंपा गया है।

इन सभी तीन तालिकाओं को बनाया जाता है जब निम्नलिखित कथन निष्पादित किया जाता है -

Base.metadata.create_all(engine)

पायथन कंसोल क्रिएट टेबल प्रश्नों के बाद निकलता है -

CREATE TABLE department (
   id INTEGER NOT NULL,
   name VARCHAR,
   PRIMARY KEY (id)
)

CREATE TABLE employee (
   id INTEGER NOT NULL,
   name VARCHAR,
   PRIMARY KEY (id)
)

CREATE TABLE link (
   department_id INTEGER NOT NULL,
   employee_id INTEGER NOT NULL,
   PRIMARY KEY (department_id, employee_id),
   FOREIGN KEY(department_id) REFERENCES department (id),
   FOREIGN KEY(employee_id) REFERENCES employee (id)
)

हम नीचे दिए गए स्क्रीनशॉट में दिखाए अनुसार SQLiteStudio का उपयोग करके mycollege.db खोलकर इसकी जांच कर सकते हैं -

आगे हम डिपार्टमेंट क्लास की तीन ऑब्जेक्ट बनाते हैं और कर्मचारी क्लास की तीन ऑब्जेक्ट्स नीचे दिखाए गए हैं -

d1 = Department(name = "Accounts")
d2 = Department(name = "Sales")
d3 = Department(name = "Marketing")

e1 = Employee(name = "John")
e2 = Employee(name = "Tony")
e3 = Employee(name = "Graham")

प्रत्येक तालिका में एक संग्रह विशेषता है जिसमें एपेंड () विधि है। हम कर्मचारी वस्तुओं को विभाग वस्तु के कर्मचारी संग्रह में जोड़ सकते हैं। इसी प्रकार, हम विभाग की वस्तुओं को विभागों में जोड़ सकते हैं, जो कर्मचारी वस्तुओं की विशेषता एकत्र करते हैं।

e1.departments.append(d1)
e2.departments.append(d3)
d1.employees.append(e3)
d2.employees.append(e2)
d3.employees.append(e1)
e3.departments.append(d2)

अब हमें केवल एक सत्र ऑब्जेक्ट सेट करना है, इसमें सभी ऑब्जेक्ट्स को जोड़ना है और नीचे दिखाए गए परिवर्तनों को करना है -

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()
session.add(e1)
session.add(e2)
session.add(d1)
session.add(d2)
session.add(d3)
session.add(e3)
session.commit()

SQL कथन के बाद पायथन कंसोल पर उत्सर्जित किया जाएगा -

INSERT INTO department (name) VALUES (?) ('Accounts',)
INSERT INTO department (name) VALUES (?) ('Sales',)
INSERT INTO department (name) VALUES (?) ('Marketing',)
INSERT INTO employee (name) VALUES (?) ('John',)
INSERT INTO employee (name) VALUES (?) ('Graham',)
INSERT INTO employee (name) VALUES (?) ('Tony',)
INSERT INTO link (department_id, employee_id) VALUES (?, ?) ((1, 2), (3, 1), (2, 3))
INSERT INTO link (department_id, employee_id) VALUES (?, ?) ((1, 1), (2, 2), (3, 3))

उपरोक्त कार्यों के प्रभाव की जांच करने के लिए, SQLiteStudio का उपयोग करें और विभाग, कर्मचारी और लिंक तालिकाओं में डेटा देखें -

डेटा प्रदर्शित करने के लिए, निम्नलिखित क्वेरी स्टेटमेंट चलाएं -

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()

for x in session.query( Department, Employee).filter(Link.department_id == Department.id, 
   Link.employee_id == Employee.id).order_by(Link.department_id).all():
   print ("Department: {} Name: {}".format(x.Department.name, x.Employee.name))

हमारे उदाहरण में आबादी के अनुसार, आउटपुट नीचे प्रदर्शित किया जाएगा -

Department: Accounts Name: John
Department: Accounts Name: Graham
Department: Sales Name: Graham
Department: Sales Name: Tony
Department: Marketing Name: John
Department: Marketing Name: Tony

SQLAlchemy विभिन्न प्रकार के डेटाबेस के साथ संवाद करने के लिए बोलियों की प्रणाली का उपयोग करता है। प्रत्येक डेटाबेस में एक समान DBAPI आवरण होता है। सभी बोलियों के लिए आवश्यक है कि एक उपयुक्त DBAPI ड्राइवर स्थापित हो।

निम्नलिखित बोलियाँ SQLAlchemy API में शामिल हैं -

  • Firebird
  • Microsoft SQL सर्वर
  • MySQL
  • Oracle
  • PostgreSQL
  • SQL
  • Sybase

URL पर आधारित इंजन ऑब्जेक्ट create_engine () फ़ंक्शन द्वारा निर्मित होता है। इन URL में उपयोगकर्ता नाम, पासवर्ड, होस्टनाम और डेटाबेस का नाम शामिल हो सकता है। अतिरिक्त कॉन्फ़िगरेशन के लिए वैकल्पिक कीवर्ड तर्क हो सकते हैं। कुछ मामलों में, एक फ़ाइल पथ स्वीकार किया जाता है, और दूसरों में, एक "डेटा स्रोत का नाम" "होस्ट" और "डेटाबेस" भागों को बदलता है। डेटाबेस URL का विशिष्ट रूप इस प्रकार है -

dialect+driver://username:password@host:port/database

PostgreSQL

PostgreSQL बोली का उपयोग करता है psycopg2डिफ़ॉल्ट DBAPI के रूप में। pg8000 एक शुद्ध-पायथन विकल्प के रूप में भी उपलब्ध है जैसा कि नीचे दिखाया गया है:

# default
engine = create_engine('postgresql://scott:tiger@localhost/mydatabase')

# psycopg2
engine = create_engine('postgresql+psycopg2://scott:tiger@localhost/mydatabase')

# pg8000
engine = create_engine('postgresql+pg8000://scott:tiger@localhost/mydatabase')

माई एसक्यूएल

MySQL बोली का उपयोग करता है mysql-pythonडिफ़ॉल्ट DBAPI के रूप में। कई MySQL DBAPI उपलब्ध हैं, जैसे कि MySQL-कनेक्टर-अजगर इस प्रकार है -

# default
engine = create_engine('mysql://scott:tiger@localhost/foo')

# mysql-python
engine = create_engine('mysql+mysqldb://scott:tiger@localhost/foo')

# MySQL-connector-python
engine = create_engine('mysql+mysqlconnector://scott:tiger@localhost/foo')

आकाशवाणी

ओरेकल बोली का उपयोग करता है cx_oracle डिफ़ॉल्ट DBAPI निम्नानुसार है -

engine = create_engine('oracle://scott:[email protected]:1521/sidname')
engine = create_engine('oracle+cx_oracle://scott:tiger@tnsname')

Microsoft SQL सर्वर

SQL सर्वर बोली का उपयोग करता है pyodbcडिफ़ॉल्ट DBAPI के रूप में। जिमसक्कल भी उपलब्ध है।

# pyodbc
engine = create_engine('mssql+pyodbc://scott:tiger@mydsn')

# pymssql
engine = create_engine('mssql+pymssql://scott:tiger@hostname:port/dbname')

SQLite

SQLite फ़ाइल-आधारित डेटाबेस से जोड़ता है, पायथन अंतर्निहित मॉड्यूल का उपयोग करके sqlite3डिफ़ॉल्ट रूप से। जैसा कि SQLite स्थानीय फ़ाइलों से जुड़ता है, URL प्रारूप थोड़ा अलग होता है। URL का "फ़ाइल" भाग डेटाबेस का फ़ाइल नाम है। एक रिश्तेदार फ़ाइल पथ के लिए, इसे नीचे दिखाए गए अनुसार तीन स्लैश की आवश्यकता होती है -

engine = create_engine('sqlite:///foo.db')

और एक निरपेक्ष फ़ाइल पथ के लिए, तीन स्लैश निम्न पथ द्वारा अनुसरण किए जाते हैं जैसे कि नीचे दिए गए हैं -

engine = create_engine('sqlite:///C:\\path\\to\\foo.db')

SQLite: मेमोरी: डेटाबेस का उपयोग करने के लिए, नीचे दिए गए अनुसार एक खाली URL निर्दिष्ट करें -

engine = create_engine('sqlite://')

निष्कर्ष

इस ट्यूटोरियल के पहले भाग में, हमने सीखा है कि SQL स्टेटमेंट्स को निष्पादित करने के लिए एक्सप्रेशन लैंग्वेज का उपयोग कैसे करें। अभिव्यक्ति भाषा पाइथन कोड में SQL कंस्ट्रक्शन को एम्बेड करती है। दूसरे भाग में, हमने SQLAlchemy की ऑब्जेक्ट रिलेशन मैपिंग क्षमता पर चर्चा की है। ORM API पायथन कक्षाओं के साथ SQL तालिकाओं को मैप करता है।