पायथन डेटा दृढ़ता - Sqlite3 मॉड्यूल
CSV, JSON, XML, इत्यादि का एक बड़ा नुकसान यह है कि ये रैंडम एक्सेस और ट्रांजेक्शन प्रोसेसिंग के लिए बहुत उपयोगी नहीं हैं क्योंकि ये काफी हद तक प्रकृति में बिना बाधा के होते हैं। इसलिए, सामग्री को संशोधित करना बहुत मुश्किल हो जाता है।
ये फ्लैट फाइलें क्लाइंट-सर्वर वातावरण के लिए उपयुक्त नहीं हैं क्योंकि इनमें अतुल्यकालिक प्रसंस्करण क्षमता की कमी होती है। असंरचित डेटा फ़ाइलों का उपयोग डेटा अतिरेक और असंगति की ओर जाता है।
रिलेशनल डेटाबेस का उपयोग करके इन समस्याओं को दूर किया जा सकता है। डेटाबेस अतिरेक और असंगति को दूर करने और डेटा अखंडता को बनाए रखने के लिए डेटा का एक संगठित संग्रह है। संबंधपरक डेटाबेस मॉडल काफी लोकप्रिय है।
इसकी मूल अवधारणा इकाई तालिका (जिसे संबंध कहा जाता है) में डेटा की व्यवस्था करना है। इकाई तालिका संरचना एक विशेषता प्रदान करती है जिसका मूल्य प्रत्येक पंक्ति के लिए अद्वितीय है। ऐसी विशेषता को कहा जाता है'primary key'।
जब एक तालिका की प्राथमिक कुंजी अन्य तालिकाओं की संरचना में दिखाई देती है, तो इसे कहा जाता है 'Foreign key'और यह दोनों के बीच संबंध का आधार बनता है। इस मॉडल के आधार पर, वर्तमान में उपलब्ध कई लोकप्रिय RDBMS उत्पाद हैं -
- GadFly
- mSQL
- MySQL
- PostgreSQL
- Microsoft SQL Server 2000
- Informix
- Interbase
- Oracle
- Sybase
- SQLite
SQLite एक लाइटवेट रिलेशनल डेटाबेस है जिसका उपयोग विभिन्न प्रकार के अनुप्रयोगों में किया जाता है। यह एक स्व-निहित, सर्वर रहित, शून्य-कॉन्फ़िगरेशन, ट्रांसेक्शनल SQL डेटाबेस इंजन है। संपूर्ण डेटाबेस एक एकल फ़ाइल है, जिसे फ़ाइल सिस्टम में कहीं भी रखा जा सकता है। यह एक ओपन-सोर्स सॉफ्टवेयर है, जिसमें बहुत छोटे पदचिह्न और शून्य कॉन्फ़िगरेशन हैं। यह लोकप्रिय रूप से एम्बेडेड उपकरणों, IOT और मोबाइल एप्लिकेशन में उपयोग किया जाता है।
सभी संबंधपरक डेटाबेस तालिकाओं में डेटा को संभालने के लिए SQL का उपयोग करते हैं। हालाँकि, पहले, इन डेटाबेसों में से प्रत्येक पायथन एप्लिकेशन के साथ जुड़ा हुआ था, जो कि डेटाबेस के प्रकार के लिए विशिष्ट पायथन मॉड्यूल की मदद से किया गया था।
इसलिए, उनके बीच संगतता की कमी थी। यदि कोई उपयोगकर्ता विभिन्न डेटाबेस उत्पाद में परिवर्तन करना चाहता है, तो यह मुश्किल साबित होगा। यह असंगति मुद्दा डीबी-एपीआई के रूप में जाना जाता है रिलेशनल डेटाबेस के लिए लगातार इंटरफेस की सिफारिश करने के लिए 'पायथन एन्हांसमेंट प्रपोजल (पीईपी 248)' को बढ़ाकर संबोधित किया गया था। नवीनतम सिफारिशों को कहा जाता हैDB-APIसंस्करण 2.0। (पीईपी 249)
पायथन के मानक पुस्तकालय में sqlite3 मॉड्यूल शामिल है जो Python प्रोग्राम के माध्यम से SQLite डेटाबेस को संभालने के लिए DB-API अनुरूप मॉड्यूल है। यह अध्याय Pyite के कनेक्टिविटी को SQLite डेटाबेस के साथ बताता है।
जैसा कि पहले उल्लेख किया गया है, Python में SQLite डेटाबेस के लिए sqlite3 मॉड्यूल के रूप में इनबिल्ट समर्थन है। अन्य डेटाबेस के लिए, संबंधित डीबी-एपीआई आज्ञाकारी पायथन मॉड्यूल को पाइप उपयोगिता की मदद से स्थापित करना होगा। उदाहरण के लिए, MySQL डेटाबेस का उपयोग करने के लिए हमें PyMySQL मॉड्यूल को स्थापित करना होगा।
pip install pymysql
DB-API में निम्नलिखित चरणों की सिफारिश की गई है -
डेटाबेस का उपयोग करके कनेक्शन स्थापित करें connect() फ़ंक्शन और कनेक्शन ऑब्जेक्ट प्राप्त करें।
कॉल cursor() कर्सर ऑब्जेक्ट प्राप्त करने के लिए कनेक्शन ऑब्जेक्ट की विधि।
SQL कथन से बना क्वेरी स्ट्रिंग निष्पादित किया जाना चाहिए।
इच्छित क्वेरी को लागू करके निष्पादित करें execute() तरीका।
कनेक्शन बंद करें।
import sqlite3
db=sqlite3.connect('test.db')
यहाँ, db test.db का प्रतिनिधित्व करने वाली कनेक्शन वस्तु है। ध्यान दें, अगर वह पहले से मौजूद नहीं है तो वह डेटाबेस बनाया जाएगा। कनेक्शन ऑब्जेक्ट डीबी के निम्नलिखित तरीके हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | cursor(): एक कर्सर ऑब्जेक्ट लौटाता है जो इस कनेक्शन का उपयोग करता है। |
2 | commit(): स्पष्ट रूप से डेटाबेस के लिए कोई भी लंबित लेनदेन करता है। |
3 | rollback(): यह वैकल्पिक विधि लेनदेन को प्रारंभिक बिंदु पर वापस ले जाने का कारण बनती है। |
4 | close(): डेटाबेस से कनेक्शन को स्थायी रूप से बंद कर देता है। |
एक कर्सर एक दिए गए SQL क्वेरी के लिए हैंडल के रूप में कार्य करता है जो परिणाम के एक या अधिक पंक्तियों की पुनर्प्राप्ति की अनुमति देता है। निम्नलिखित कथन का उपयोग करते हुए SQL प्रश्नों को निष्पादित करने के लिए कनेक्शन से कर्सर ऑब्जेक्ट प्राप्त किया जाता है -
cur=db.cursor()
कर्सर ऑब्जेक्ट में निम्नलिखित तरीके परिभाषित हैं -
अनु क्रमांक | तरीके और विवरण |
---|---|
1 | execute() स्ट्रिंग पैरामीटर में SQL क्वेरी निष्पादित करता है। |
2 | executemany() Tuples की सूची में मापदंडों के एक सेट का उपयोग करके SQL क्वेरी को निष्पादित करता है। |
3 | fetchone() अगली पंक्ति को क्वेरी परिणाम सेट से प्राप्त करता है। |
4 | fetchall() क्वेरी परिणाम सेट से सभी शेष पंक्तियों को प्राप्त करता है। |
5 | callproc() एक संग्रहीत प्रक्रिया को कॉल करता है। |
6 | close() कर्सर ऑब्जेक्ट को बंद करता है। |
निम्नलिखित कोड test.db में एक तालिका बनाता है: -
import sqlite3
db=sqlite3.connect('test.db')
cur =db.cursor()
cur.execute('''CREATE TABLE student (
StudentID INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT (20) NOT NULL,
age INTEGER,
marks REAL);''')
print ('table created successfully')
db.close()
डेटाबेस में वांछित डेटा अखंडता हासिल की है commit() तथा rollback()कनेक्शन वस्तु के तरीके। SQL क्वेरी स्ट्रिंग में गलत SQL क्वेरी हो सकती है जो अपवाद को बढ़ा सकती है, जिसे ठीक से हैंडल किया जाना चाहिए। उसके लिए, निष्पादित खंड () स्टेटम को कोशिश ब्लॉक के भीतर रखा गया है। यदि यह सफल है, तो परिणाम कमिट () विधि का उपयोग करके लगातार सहेजा जाता है। यदि क्वेरी विफल हो जाती है, तो रोलबैक () पद्धति का उपयोग करके लेनदेन पूर्ववत है।
निम्नलिखित कोड परीक्षण तालिका में छात्र तालिका पर INSERT क्वेरी निष्पादित करता है।
import sqlite3
db=sqlite3.connect('test.db')
qry="insert into student (name, age, marks) values('Abbas', 20, 80);"
try:
cur=db.cursor()
cur.execute(qry)
db.commit()
print ("record added successfully")
except:
print ("error in query")
db.rollback()
db.close()
यदि आप उपयोगकर्ता इनपुट द्वारा गतिशील रूप से प्रदान किए गए INSERT क्वेरी के मान खंड में डेटा चाहते हैं, तो Python DB-API में अनुशंसित पैरामीटर प्रतिस्थापन का उपयोग करें। ? क्वेरी स्ट्रिंग में प्लेसहोल्डर के रूप में चरित्र का उपयोग किया जाता है और निष्पादन () विधि में एक टपल के रूप में मान प्रदान करता है। निम्न उदाहरण पैरामीटर प्रतिस्थापन विधि का उपयोग करके एक रिकॉर्ड सम्मिलित करता है। नाम, आयु और अंकों को इनपुट के रूप में लिया जाता है।
import sqlite3
db=sqlite3.connect('test.db')
nm=input('enter name')
a=int(input('enter age'))
m=int(input('enter marks'))
qry="insert into student (name, age, marks) values(?,?,?);"
try:
cur=db.cursor()
cur.execute(qry, (nm,a,m))
db.commit()
print ("one record added successfully")
except:
print("error in operation")
db.rollback()
db.close()
Sqlite3 मॉड्यूल को परिभाषित करता है executemany()विधि जो एक साथ कई रिकॉर्ड जोड़ने में सक्षम है। जोड़े जाने वाले डेटा को ट्यूपल्स की सूची में दिया जाना चाहिए, प्रत्येक ट्यूपल में एक रिकॉर्ड होगा। सूची ऑब्जेक्ट क्वेरी स्ट्रिंग के साथ, निष्पादक () विधि का पैरामीटर है। हालाँकि, निष्पादक () विधि कुछ अन्य मॉड्यूल द्वारा समर्थित नहीं है।
UPDATEक्वेरी में आम तौर पर एक तार्किक अभिव्यक्ति होती है, जहां निर्दिष्ट किया गया है निष्पादन () विधि में क्वेरी स्ट्रिंग में एक UPDATE क्वेरी सिंटैक्स होना चाहिए। नाम = 'अनिल' के लिए 'आयु' के मान को 23 तक अपडेट करने के लिए, नीचे दिए गए स्ट्रिंग को परिभाषित करें:
qry="update student set age=23 where name='Anil';"
अद्यतन प्रक्रिया को अधिक गतिशील बनाने के लिए, हम ऊपर वर्णित अनुसार पैरामीटर प्रतिस्थापन विधि का उपयोग करते हैं।
import sqlite3
db=sqlite3.connect('test.db')
nm=input(‘enter name’)
a=int(input(‘enter age’))
qry="update student set age=? where name=?;"
try:
cur=db.cursor()
cur.execute(qry, (a, nm))
db.commit()
print("record updated successfully")
except:
print("error in query")
db.rollback()
db.close()
इसी तरह, DELETE ऑपरेशन SQL के DELETE क्वेरी सिंटैक्स वाले स्ट्रिंग के साथ निष्पादित () विधि को कॉल करके किया जाता है। संयोग से,DELETE क्वेरी में भी आम तौर पर एक होता है WHERE खंड।
import sqlite3
db=sqlite3.connect('test.db')
nm=input(‘enter name’)
qry="DELETE from student where name=?;"
try:
cur=db.cursor()
cur.execute(qry, (nm,))
db.commit()
print("record deleted successfully")
except:
print("error in operation")
db.rollback()
db.close()
एक डेटाबेस टेबल पर महत्वपूर्ण कार्यों में से एक से रिकॉर्ड की पुनर्प्राप्ति है। एसक्यूएल प्रदान करता हैSELECTउद्देश्य के लिए क्वेरी। जब एक स्ट्रिंग जिसमें SELECT क्वेरी सिंटैक्स होता है, निष्पादित करने के लिए दिया जाता है () विधि, परिणाम सेट ऑब्जेक्ट लौटाया जाता है। एक कर्सर ऑब्जेक्ट के साथ दो महत्वपूर्ण विधियां हैं, जिसके उपयोग से परिणाम सेट से एक या कई रिकॉर्ड प्राप्त किए जा सकते हैं।
fetchone ()
परिणाम सेट से अगला उपलब्ध रिकॉर्ड प्राप्त करता है। यह एक रिकॉर्ड है जिसमें भ्रूण के रिकॉर्ड के प्रत्येक कॉलम के मान शामिल हैं।
fetchall ()
बचे हुए सभी रिकॉर्डों को टुपल्स की सूची के रूप में प्राप्त करता है। प्रत्येक टपल एक रिकॉर्ड से मेल खाती है और तालिका में प्रत्येक कॉलम के मान शामिल हैं।
निम्नलिखित उदाहरण छात्र तालिका में सभी रिकॉर्डों को सूचीबद्ध करता है
import sqlite3
db=sqlite3.connect('test.db')
37
sql="SELECT * from student;"
cur=db.cursor()
cur.execute(sql)
while True:
record=cur.fetchone()
if record==None:
break
print (record)
db.close()
यदि आप SQLite डेटाबेस के बजाय एक MySQL डेटाबेस का उपयोग करने की योजना बनाते हैं, तो आपको इंस्टॉल करने की आवश्यकता है PyMySQLमॉड्यूल जैसा कि ऊपर वर्णित है। डेटाबेस कनेक्टिविटी प्रक्रिया के सभी चरण एक ही हैं, क्योंकि MySQL डेटाबेस एक सर्वर पर स्थापित है, कनेक्ट () फ़ंक्शन को URL और लॉगिन क्रेडेंशियल्स की आवश्यकता है।
import pymysql
con=pymysql.connect('localhost', 'root', '***')
केवल एक चीज जो SQLite के साथ भिन्न हो सकती है वह है MySQL विशिष्ट डेटा प्रकार। इसी तरह, किसी भी ODBC संगत डेटाबेस का उपयोग पायोडबक मॉड्यूल स्थापित करके पायथन के साथ किया जा सकता है।