पायथन डेटा की दृढ़ता - SQLAlchemy
कोई भी संबंधपरक डेटाबेस तालिकाओं में डेटा रखता है। तालिका संरचना डेटा प्रकार की विशेषताओं को परिभाषित करती है जो मूल रूप से प्राथमिक डेटा प्रकारों की होती हैं जो केवल संबंधित डेटा प्रकारों के पायथन में मैप की जाती हैं। हालाँकि, पायथन के उपयोगकर्ता-परिभाषित ऑब्जेक्ट्स को एसक्यूएल टेबल से लगातार संग्रहीत और पुनः प्राप्त नहीं किया जा सकता है।
यह SQL प्रकार और ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग भाषाओं जैसे Python के बीच असमानता है। SQL में दूसरों के लिए समान डेटा प्रकार नहीं है जैसे तानाशाह, टपल, सूची या कोई भी उपयोगकर्ता परिभाषित वर्ग।
यदि आपको किसी रिलेशनल डेटाबेस में ऑब्जेक्ट को स्टोर करना है, तो यह इंस्टेंस क्वेश्चन को निष्पादित करने से पहले, पहले SQL डेटा प्रकारों में डिक्रिप्ट किया जाना चाहिए। दूसरी ओर, SQL तालिका से प्राप्त डेटा प्राथमिक प्रकारों में है। पाइथन लिपि में उपयोग के लिए इच्छित प्रकार की एक पाइथन वस्तु का निर्माण करना होगा। यह वह जगह है जहाँ ऑब्जेक्ट रिलेशनल मैपर उपयोगी होते हैं।
ऑब्जेक्ट रिलेशन मैपर (ORM)
एक Object Relation Mapper(ORM) एक वर्ग और एक SQL तालिका के बीच का इंटरफ़ेस है। एक पायथन वर्ग को डेटाबेस में एक निश्चित तालिका में मैप किया जाता है, ताकि ऑब्जेक्ट और SQL प्रकारों के बीच रूपांतरण स्वचालित रूप से किया जाए।
पायथन कोड में लिखा गया छात्र वर्ग डेटाबेस में छात्र तालिका में मैप किया जाता है। नतीजतन, सभी सीआरयूडी संचालन कक्षा के संबंधित तरीकों को कॉल करके किया जाता है। यह अजगर स्क्रिप्ट में हार्ड कोडित एसक्यूएल प्रश्नों को निष्पादित करने की आवश्यकता को समाप्त करता है।
ORM पुस्तकालय इस प्रकार कच्चे SQL प्रश्नों पर एक अमूर्त परत के रूप में कार्य करता है और तेजी से अनुप्रयोग विकास में मदद कर सकता है। SQLAlchemyपायथन के लिए एक लोकप्रिय वस्तु संबंधपरक मैपर है। मॉडल ऑब्जेक्ट की स्थिति के किसी भी हेरफेर को डेटाबेस तालिका में इसकी संबंधित पंक्ति के साथ सिंक्रनाइज़ किया जाता है।
SQLALchemy लाइब्रेरी शामिल है ORM API और SQL अभिव्यक्ति भाषा (SQLAlchemy Core)। अभिव्यक्ति भाषा सीधे रिलेशनल डेटाबेस के आदिम निर्माण को निष्पादित करती है।
ORM SQL अभिव्यक्ति भाषा के शीर्ष पर निर्मित उपयोग का एक उच्च स्तरीय और अमूर्त पैटर्न है। यह कहा जा सकता है कि ORM अभिव्यक्ति भाषा का एक अनुप्रयुक्त उपयोग है। हम SQLAlchemy ORM API पर चर्चा करेंगे और इस विषय में SQLite डेटाबेस का उपयोग करेंगे।
SQLAlchemy अपने संबंधित DBAPI कार्यान्वयन के माध्यम से विभिन्न प्रकार के डेटाबेस के साथ एक बोली प्रणाली का उपयोग करके संचार करता है। सभी बोलियों के लिए आवश्यक है कि एक उपयुक्त DBAPI ड्राइवर स्थापित हो। निम्नलिखित प्रकार के डेटाबेस के लिए बोलियाँ शामिल हैं -
- Firebird
- Microsoft SQL सर्वर
- MySQL
- Oracle
- PostgreSQL
- SQLite
- Sybase
पाइप उपयोगिता का उपयोग करते हुए SQLAlchemy की स्थापना आसान और सरल है।
pip install sqlalchemy
यह जांचने के लिए कि क्या SQLalchemy ठीक से स्थापित है और इसका संस्करण, पायथन प्रॉम्प्ट पर निम्नलिखित दर्ज करें -
>>> import sqlalchemy
>>>sqlalchemy.__version__
'1.3.11'
डेटाबेस के साथ इंटरैक्शन इंजन ऑब्जेक्ट के माध्यम से किया जाता है जिसे रिटर्न वैल्यू के रूप में प्राप्त किया जाता है create_engine() समारोह।
engine =create_engine('sqlite:///mydb.sqlite')
SQLite इन-मेमोरी डेटाबेस के निर्माण की अनुमति देता है। इन-मेमोरी डेटाबेस के लिए SQLAlchemy इंजन निम्नानुसार बनाया गया है -
from sqlalchemy import create_engine
engine=create_engine('sqlite:///:memory:')
यदि आप इसके बजाय MySQL डेटाबेस का उपयोग करने का इरादा रखते हैं, तो इसके DB-API मॉड्यूल - pymysql और संबंधित बोली ड्राइवर का उपयोग करें।
engine = create_engine('mysql+pymydsql://root@localhost/mydb')
Create_engine में एक वैकल्पिक प्रतिध्वनि तर्क है। यदि यह सही है, तो इंजन द्वारा उत्पन्न SQL क्वेरीज़ टर्मिनल पर गूँजती होगी।
SQLAlchemy शामिल हैं declarative baseकक्षा। यह मॉडल कक्षाओं और मैप किए गए तालिकाओं की एक सूची के रूप में कार्य करता है।
from sqlalchemy.ext.declarative import declarative_base
base=declarative_base()
अगला कदम एक मॉडल वर्ग को परिभाषित करना है। यह आधार से प्राप्त होना चाहिए - ऊपर के रूप में घोषणात्मक_बेस वर्ग का उद्देश्य।
सेट __tablename__ आपके द्वारा डेटाबेस में बनाई गई तालिका के नाम की संपत्ति। अन्य विशेषताएँ खेतों के अनुरूप हैं। SQLAlchemy में प्रत्येक एक कॉलम ऑब्जेक्ट है और इसका डेटा प्रकार नीचे दी गई सूची में से एक है -
- BigInteger
- Boolean
- Date
- DateTime
- Float
- Integer
- Numeric
- SmallInteger
- String
- Text
- Time
निम्नलिखित कोड छात्र के रूप में नामित मॉडल वर्ग है जिसे छात्रों की तालिका में मैप किया जाता है।
#myclasses.py
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String, Numeric
base=declarative_base()
class Student(base):
__tablename__='Students'
StudentID=Column(Integer, primary_key=True)
name=Column(String)
age=Column(Integer)
marks=Column(Numeric)
एक छात्र तालिका बनाने के लिए, जिसके पास एक समान संरचना है, आधार वर्ग के लिए create_all () पद्धति को निष्पादित करें।
base.metadata.create_all(engine)
अब हमें अपने छात्र वर्ग की एक वस्तु घोषित करनी होगी। सभी डेटाबेस लेनदेन जैसे डेटाबेस से डेटा जोड़ना, हटाना या पुनर्प्राप्त करना, एक सेशन ऑब्जेक्ट द्वारा नियंत्रित किया जाता है।
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
sessionobj = Session()
छात्र के ऑब्जेक्ट में संग्रहीत डेटा को सत्र के ऐड () विधि द्वारा भौतिक रूप से अंतर्निहित तालिका में जोड़ा जाता है।
s1 = Student(name='Juhi', age=25, marks=200)
sessionobj.add(s1)
sessionobj.commit()
यहां, छात्रों की तालिका में रिकॉर्ड जोड़ने के लिए संपूर्ण कोड है। जैसे ही इसे निष्पादित किया जाता है, संबंधित SQL कथन लॉग कंसोल पर प्रदर्शित होता है।
from sqlalchemy import Column, Integer, String
from sqlalchemy import create_engine
from myclasses import Student, base
engine = create_engine('sqlite:///college.db', echo=True)
base.metadata.create_all(engine)
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
sessionobj = Session()
s1 = Student(name='Juhi', age=25, marks=200)
sessionobj.add(s1)
sessionobj.commit()
कंसोल आउटपुट
CREATE TABLE "Students" (
"StudentID" INTEGER NOT NULL,
name VARCHAR,
age INTEGER,
marks NUMERIC,
PRIMARY KEY ("StudentID")
)
INFO sqlalchemy.engine.base.Engine ()
INFO sqlalchemy.engine.base.Engine COMMIT
INFO sqlalchemy.engine.base.Engine BEGIN (implicit)
INFO sqlalchemy.engine.base.Engine INSERT INTO "Students" (name, age, marks) VALUES (?, ?, ?)
INFO sqlalchemy.engine.base.Engine ('Juhi', 25, 200.0)
INFO sqlalchemy.engine.base.Engine COMMIT
session ऑब्जेक्ट एकल लेनदेन में एक से अधिक ऑब्जेक्ट सम्मिलित करने के लिए add_all () विधि भी प्रदान करता है।
sessionobj.add_all([s2,s3,s4,s5])
sessionobj.commit()
अब, रिकॉर्ड्स को तालिका में जोड़ा जाता है, हम इसे उसी तरह से प्राप्त करना चाहेंगे, जैसा कि SELECT क्वेरी करती है। सत्र ऑब्जेक्ट में कार्य करने के लिए क्वेरी () विधि है। क्वेरी ऑब्जेक्ट हमारे छात्र मॉडल पर क्वेरी () विधि द्वारा लौटाया जाता है।
qry=seesionobj.query(Student)
इस क्वेरी ऑब्जेक्ट की प्राप्त विधि का उपयोग करें (प्राइमरी की) दिए गए ऑब्जेक्ट के अनुरूप।
S1=qry.get(1)
जबकि इस कथन को निष्पादित किया गया है, कंसोल पर गूँजने वाला इसका संगत एसक्यूएल विवरण इस प्रकार होगा -
BEGIN (implicit)
SELECT "Students"."StudentID" AS "Students_StudentID", "Students".name AS
"Students_name", "Students".age AS "Students_age",
"Students".marks AS "Students_marks"
FROM "Students"
WHERE "Products"."Students" = ?
sqlalchemy.engine.base.Engine (1,)
Query.all () विधि उन सभी ऑब्जेक्ट्स की एक सूची देता है, जिन्हें लूप का उपयोग करके ट्रेस किया जा सकता है।
from sqlalchemy import Column, Integer, String, Numeric
from sqlalchemy import create_engine
from myclasses import Student,base
engine = create_engine('sqlite:///college.db', echo=True)
base.metadata.create_all(engine)
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
sessionobj = Session()
qry=sessionobj.query(Students)
rows=qry.all()
for row in rows:
print (row)
मैप की गई तालिका में रिकॉर्ड अपडेट करना बहुत आसान है। आपको केवल प्राप्त () विधि का उपयोग करके एक रिकॉर्ड प्राप्त करना है, वांछित विशेषता के लिए एक नया मान असाइन करें और फिर सत्र ऑब्जेक्ट का उपयोग करके परिवर्तन करें। नीचे हम जूही छात्र के अंकों को 100 में बदलते हैं।
S1=qry.get(1)
S1.marks=100
sessionobj.commit()
सत्र से वांछित वस्तु को हटाकर एक रिकॉर्ड को हटाना उतना ही आसान है।
S1=qry.get(1)
Sessionobj.delete(S1)
sessionobj.commit()