SQLite - पायथन

इस अध्याय में, आप सीखेंगे कि पायथन कार्यक्रमों में SQLite का उपयोग कैसे करें।

इंस्टालेशन

SQLite3 को sqlite3 मॉड्यूल का उपयोग करके पायथन के साथ एकीकृत किया जा सकता है, जिसे गेरहार्ड हारिंग ने लिखा था। यह PEP 249 द्वारा वर्णित DB-API 2.0 विनिर्देश के साथ एक SQL इंटरफ़ेस अनुपालन प्रदान करता है। आपको इस मॉड्यूल को अलग से स्थापित करने की आवश्यकता नहीं है क्योंकि यह डिफ़ॉल्ट रूप से Python संस्करण 2.5.x के साथ भेज दिया गया है।

Sqlite3 मॉड्यूल का उपयोग करने के लिए, आपको पहले एक कनेक्शन ऑब्जेक्ट बनाना होगा जो डेटाबेस का प्रतिनिधित्व करता है और फिर वैकल्पिक रूप से आप एक कर्सर ऑब्जेक्ट बना सकते हैं, जो आपको सभी SQL स्टेटमेंट को निष्पादित करने में मदद करेगा।

अजगर sqlite3 मॉड्यूल एपीआई

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

अनु क्रमांक। एपीआई और विवरण
1

sqlite3.connect(database [,timeout ,other optional arguments])

यह एपीआई SQLite डेटाबेस फ़ाइल के लिए एक कनेक्शन खोलता है। आप डेटाबेस पर डेटाबेस कनेक्शन को खोलने के लिए ": मेमोरी:" का उपयोग कर सकते हैं जो डिस्क पर ऑन करने के बजाय रैम में रहता है। यदि डेटाबेस सफलतापूर्वक खोला गया है, तो यह कनेक्शन ऑब्जेक्ट लौटाता है।

जब एक डेटाबेस कई कनेक्शनों द्वारा एक्सेस किया जाता है, और एक प्रक्रिया डेटाबेस को संशोधित करती है, तो SQLite डेटाबेस को तब तक लॉक किया जाता है जब तक कि लेन-देन प्रतिबद्ध न हो। टाइमआउट पैरामीटर निर्दिष्ट करता है कि कनेक्शन को अपवाद बढ़ाने तक लॉक को दूर जाने के लिए कितने समय तक इंतजार करना चाहिए। टाइमआउट पैरामीटर के लिए डिफ़ॉल्ट 5.0 (पांच सेकंड) है।

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

2

connection.cursor([cursorClass])

यह दिनचर्या एक निर्माण करती है cursorजिसका उपयोग आपके पूरे डेटाबेस प्रोग्रामिंग में पायथन के साथ किया जाएगा। यह विधि एकल वैकल्पिक पैरामीटर कर्सरक्लास को स्वीकार करती है। यदि आपूर्ति की जाती है, तो यह एक कस्टम कर्सर क्लास होना चाहिए जो sqlite3.Cursor का विस्तार करता है।

3

cursor.execute(sql [, optional parameters])

यह रूटीन SQL कथन निष्पादित करता है। एसक्यूएल विवरण को परिमाणित किया जा सकता है (यानी एसक्यूएल शाब्दिक के बजाय प्लेसहोल्डर)। Sqlite3 मॉड्यूल दो प्रकार के प्लेसहोल्डर्स का समर्थन करता है: प्रश्न चिह्न और नामित प्लेसहोल्डर (नाम शैली)।

For example - RPG.execute ("लोगों के मूल्यों में डालें (?)?", (कौन, उम्र)

4

connection.execute(sql [, optional parameters])

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

5

cursor.executemany(sql, seq_of_parameters)

यह दिनचर्या अनुक्रम sql में पाए जाने वाले सभी पैरामीटर अनुक्रमों या मैपिंग के विरुद्ध SQL कमांड निष्पादित करता है।

6

connection.executemany(sql[, parameters])

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

7

cursor.executescript(sql_script)

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

8

connection.executescript(sql_script)

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

9

connection.total_changes()

यह रूटीन डेटाबेस कनेक्शन खोले जाने के बाद, संशोधित, सम्मिलित या हटा दी गई डेटाबेस पंक्तियों की कुल संख्या को लौटाता है।

10

connection.commit()

यह विधि वर्तमान लेनदेन को लागू करती है। यदि आप इस विधि को नहीं कहते हैं, तो अंतिम कॉल करने के बाद से आपके द्वारा किया गया कुछ भी (अन्य डेटाबेस कनेक्शन से दिखाई नहीं देता है)।

1 1

connection.rollback()

यह विधि पिछले कॉल के बाद से डेटाबेस में किसी भी परिवर्तन को वापस लाती है।

12

connection.close()

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

13

cursor.fetchone()

यह पद्धति एक क्वेरी अनुक्रम सेट की अगली पंक्ति लाती है, एक एकल अनुक्रम लौटाती है, या जब कोई अधिक डेटा उपलब्ध नहीं होता है।

14

cursor.fetchmany([size = cursor.arraysize])

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

15

cursor.fetchall()

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

डेटाबेस से कनेक्ट करें

पायथन कोड के बाद पता चलता है कि मौजूदा डेटाबेस से कैसे कनेक्ट किया जाए। यदि डेटाबेस मौजूद नहीं है, तो इसे बनाया जाएगा और अंत में एक डेटाबेस ऑब्जेक्ट वापस कर दिया जाएगा।

#!/usr/bin/python

import sqlite3

conn = sqlite3.connect('test.db')

print "Opened database successfully";

यहां, आप विशेष नाम के रूप में डेटाबेस नाम की आपूर्ति भी कर सकते हैं :memory:RAM में डेटाबेस बनाने के लिए। अब, हमारे डेटाबेस बनाने के लिए उपरोक्त प्रोग्राम को चलाते हैंtest.dbवर्तमान निर्देशिका में। आप अपनी आवश्यकता के अनुसार अपना रास्ता बदल सकते हैं। उपरोक्त कोड को sqlite.py फ़ाइल में रखें और इसे नीचे दिखाए अनुसार निष्पादित करें। यदि डेटाबेस सफलतापूर्वक बनाया गया है, तो यह निम्न संदेश प्रदर्शित करेगा।

$chmod +x sqlite.py
$./sqlite.py
Open database successfully

एक तालिका बनाएँ

पहले बनाए गए डेटाबेस में तालिका बनाने के लिए पायथन प्रोग्राम का उपयोग किया जाएगा।

#!/usr/bin/python

import sqlite3

conn = sqlite3.connect('test.db')
print "Opened database successfully";

conn.execute('''CREATE TABLE COMPANY
         (ID INT PRIMARY KEY     NOT NULL,
         NAME           TEXT    NOT NULL,
         AGE            INT     NOT NULL,
         ADDRESS        CHAR(50),
         SALARY         REAL);''')
print "Table created successfully";

conn.close()

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह आपके में कंपनी तालिका बनाएगा test.db और यह निम्नलिखित संदेश प्रदर्शित करेगा -

Opened database successfully
Table created successfully

INSERT ऑपरेशन

पायथन कार्यक्रम के बाद उपरोक्त उदाहरण में बनाई गई कंपनी की तालिका में रिकॉर्ड बनाने का तरीका दिखाया गया है।

#!/usr/bin/python

import sqlite3

conn = sqlite3.connect('test.db')
print "Opened database successfully";

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (1, 'Paul', 32, 'California', 20000.00 )");

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (2, 'Allen', 25, 'Texas', 15000.00 )");

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )");

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 )");

conn.commit()
print "Records created successfully";
conn.close()

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह कंपनी तालिका में दिए गए रिकॉर्ड बनाएगा और यह निम्नलिखित दो लाइनें प्रदर्शित करेगा -

Opened database successfully
Records created successfully

ऑपरेशन का चयन करें

पायथन कार्यक्रम के बाद पता चलता है कि उपरोक्त उदाहरण में बनाई गई कंपनी तालिका से रिकॉर्ड कैसे प्राप्त करें और प्रदर्शित करें।

#!/usr/bin/python

import sqlite3

conn = sqlite3.connect('test.db')
print "Opened database successfully";

cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
   print "ID = ", row[0]
   print "NAME = ", row[1]
   print "ADDRESS = ", row[2]
   print "SALARY = ", row[3], "\n"

print "Operation done successfully";
conn.close()

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।

Opened database successfully
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 20000.0

ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000.0

ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000.0

ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000.0

Operation done successfully

अद्यतन ऑपरेशन

पायथन कोड का पालन करना दिखाता है कि किसी भी रिकॉर्ड को अपडेट करने के लिए UPDATE स्टेटमेंट का उपयोग कैसे करें और फिर कंपनी टेबल से अपडेट किए गए रिकॉर्ड को लाने और प्रदर्शित करने के लिए।

#!/usr/bin/python

import sqlite3

conn = sqlite3.connect('test.db')
print "Opened database successfully";

conn.execute("UPDATE COMPANY set SALARY = 25000.00 where ID = 1")
conn.commit()
print "Total number of rows updated :", conn.total_changes

cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
   print "ID = ", row[0]
   print "NAME = ", row[1]
   print "ADDRESS = ", row[2]
   print "SALARY = ", row[3], "\n"

print "Operation done successfully";
conn.close()

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।

Opened database successfully
Total number of rows updated : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 25000.0

ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000.0

ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000.0

ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000.0

Operation done successfully

DELETE ऑपरेशन

पायथन कोड का पालन करने से पता चलता है कि किसी भी रिकॉर्ड को हटाने के लिए DELETE स्टेटमेंट का उपयोग कैसे करें और फिर कंपनी टेबल से शेष रिकॉर्ड को प्राप्त करें और प्रदर्शित करें।

#!/usr/bin/python

import sqlite3

conn = sqlite3.connect('test.db')
print "Opened database successfully";

conn.execute("DELETE from COMPANY where ID = 2;")
conn.commit()
print "Total number of rows deleted :", conn.total_changes

cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
   print "ID = ", row[0]
   print "NAME = ", row[1]
   print "ADDRESS = ", row[2]
   print "SALARY = ", row[3], "\n"

print "Operation done successfully";
conn.close()

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।

Opened database successfully
Total number of rows deleted : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 20000.0

ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000.0

ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000.0

Operation done successfully