अजगर - डेटाबेस और एसक्यूएल

पायथन प्रोग्रामिंग भाषा में डेटाबेस प्रोग्रामिंग के लिए शक्तिशाली विशेषताएं हैं। अजगर विभिन्न डेटाबेस जैसे SQLite, MySQL, Oracle, Sybase, PostgreSQL आदि का समर्थन करता है। Python डेटा परिभाषा भाषा (DDL), डेटा हेरफेर भाषा (DML) और डेटा क्वेरी स्टेटमेंट का भी समर्थन करता है। डेटाबेस इंटरफेस के लिए पायथन मानक पायथन डीबी-एपीआई है। अधिकांश पायथन डेटाबेस इंटरफेस इस मानक का पालन करते हैं।

यहां उपलब्ध पायथन डेटाबेस इंटरफेस की सूची दी गई है: पायथन डेटाबेस इंटरफेस और एपीआई । आपके द्वारा उपयोग किए जाने वाले प्रत्येक डेटाबेस के लिए आपको एक अलग DB एपीआई मॉड्यूल डाउनलोड करना होगा।

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

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

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

#!/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

ऑपरेशन डालें

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

#!/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 स्टेटमेंट का उपयोग कैसे करें और फिर कंपनी तालिका से शेष रिकॉर्ड प्राप्त करें और प्रदर्शित करें।

#!/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