पायथन SQLite - त्वरित गाइड
SQLite3 को Pylon के साथ sqlite3 मॉड्यूल का उपयोग करके एकीकृत किया जा सकता है, जिसे Gerhard Haring ने लिखा था। यह 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 डेटाबेस फ़ाइल के लिए एक कनेक्शन खोलता है। आप डेटाबेस पर डेटाबेस कनेक्शन को खोलने के लिए ": मेमोरी:" का उपयोग कर सकते हैं जो डिस्क पर ऑन करने के बजाय रैम में रहता है। यदि डेटाबेस सफलतापूर्वक खोला गया है, तो यह कनेक्शन ऑब्जेक्ट लौटाता है। |
2 | connection.cursor([cursorClass]) यह रूटीन एक कर्सर बनाता है जो आपके डेटाबेस प्रोग्रामिंग में पायथन के साथ उपयोग किया जाएगा। यह विधि एकल वैकल्पिक पैरामीटर कर्सरक्लास को स्वीकार करती है। यदि आपूर्ति की जाती है, तो यह एक कस्टम कर्सर क्लास होना चाहिए जो 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() यह रूटीन क्वेरी परिणाम की सभी (शेष) पंक्तियों को एक सूची में लाती है। कोई पंक्तियाँ उपलब्ध नहीं होने पर एक खाली सूची दी जाती है। |
SQLite ओपन कमांड प्रॉम्प्ट के साथ संबंध स्थापित करने के लिए, उस स्थान से ब्राउज़ करें जहां आपने SQLite स्थापित किया है और बस कमांड निष्पादित करें sqlite3 जैसा कि नीचे दिखाया गया है -
पायथन का उपयोग करके कनेक्शन स्थापित करना
आप SQLite3 डेटाबेस का उपयोग SQLite3 अजगर मॉड्यूल के साथ संवाद कर सकते हैं। ऐसा करने के लिए, सबसे पहले आपको एक कनेक्शन स्थापित करने (कनेक्शन ऑब्जेक्ट बनाने) की आवश्यकता है।
SQLite3 डेटाबेस के साथ एक कनेक्शन स्थापित करने के लिए आपको अजगर की ज़रूरत है -
आयात कथन का उपयोग कर sqlite3 मॉड्यूल आयात करें।
कनेक्ट () विधि उस डेटाबेस के नाम को स्वीकार करती है जिसे आपको एक पैरामीटर के रूप में कनेक्ट करने की आवश्यकता होती है और, एक कनेक्शन ऑब्जेक्ट देता है।
उदाहरण
import sqlite3
conn = sqlite3.connect('example.db')
उत्पादन
print("Connection established ..........")
SQLite CREATE TABLE स्टेटमेंट का उपयोग करके आप डेटाबेस में टेबल बना सकते हैं।
वाक्य - विन्यास
SQLite डेटाबेस में टेबल बनाने के लिए सिंटैक्स निम्नलिखित है -
CREATE TABLE database_name.table_name(
column1 datatype PRIMARY KEY(one or more columns),
column2 datatype,
column3 datatype,
.....
columnN datatype
);
उदाहरण
SQLite क्वेरी / स्टेटमेंट के बाद नाम के साथ एक टेबल बनाता है CRICKETERS SQLite डेटाबेस में -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
आइए हम CRICKETERS तालिका में प्रत्येक खिलाड़ी के वन-डे क्रिकेट आंकड़ों का वर्णन करते हुए एक और तालिका OdiStats बनाएं।
sqlite> CREATE TABLE ODIStats (
First_Name VARCHAR(255),
Matches INT,
Runs INT,
AVG FLOAT,
Centuries INT,
HalfCenturies INT
);
sqlite>
आप SQLite डेटाबेस में एक डेटाबेस में तालिकाओं की सूची प्राप्त कर सकते हैं .tablesआदेश। तालिका बनाने के बाद, यदि आप तालिकाओं की सूची को सत्यापित कर सकते हैं, तो आप इसमें नई बनाई गई तालिका का निरीक्षण कर सकते हैं -
sqlite> . tables
CRICKETERS ODIStats
sqlite>
पायथन का उपयोग करके एक तालिका बनाना
Cursor ऑब्जेक्ट में quires और fetch data आदि को निष्पादित करने के सभी तरीके हैं। कनेक्शन क्लास का कर्सर विधि एक कर्सर ऑब्जेक्ट देता है।
इसलिए, अजगर का उपयोग कर SQLite डेटाबेस में एक तालिका बनाने के लिए -
कनेक्ट () विधि का उपयोग करके डेटाबेस के साथ संबंध स्थापित करें।
उपरोक्त बनाई गई कनेक्शन ऑब्जेक्ट पर कर्सर () विधि को लागू करके एक कर्सर ऑब्जेक्ट बनाएं।
अब Cursor वर्ग के निष्पादन () पद्धति का उपयोग करके क्रिएट टेबल स्टेटमेंट को निष्पादित करें।
उदाहरण
पायथन कार्यक्रम के बाद SQLite3 में कर्मचारी नाम की एक तालिका बनाता है -
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Doping EMPLOYEE table if already exists.
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
#Creating table as per requirement
sql ='''CREATE TABLE EMPLOYEE(
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT
)'''
cursor.execute(sql)
print("Table created successfully........")
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
Table created successfully........
आप INSERT INTO कथन का उपयोग करके SQLite की मौजूदा तालिका में नई पंक्तियाँ जोड़ सकते हैं। इसमें, आपको तालिका का नाम, कॉलम के नाम और मान (कॉलम के नाम के समान क्रम में) निर्दिष्ट करने की आवश्यकता है।
वाक्य - विन्यास
निम्नलिखित INSERT बयान की सिफारिश की वाक्य रचना है -
INSERT INTO TABLE_NAME (column1, column2, column3,...columnN)
VALUES (value1, value2, value3,...valueN);
जहां, column1, column2, column3, .. एक तालिका के स्तंभों के नाम हैं और value1, value2, value3, ... वे मान हैं जिन्हें आपको तालिका में सम्मिलित करने की आवश्यकता है।
उदाहरण
मान लें कि हमने नीचे दिखाए गए अनुसार क्रेट टेबल स्टेटमेंट का उपयोग करके क्रिकेटर नाम से एक टेबल बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
PostgreSQL स्टेटमेंट के बाद उपरोक्त बनाई गई तालिका में एक पंक्ति सम्मिलित होती है।
sqlite> insert into CRICKETERS (First_Name, Last_Name, Age, Place_Of_Birth, Country)
values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite>
INSERT INTO स्टेटमेंट का उपयोग करके रिकॉर्ड सम्मिलित करते समय , यदि आप किसी भी कॉलम के नाम को छोड़ते हैं, तो यह रिकॉर्ड कॉलम में खाली स्थानों को छोड़कर डाला जाएगा, जिसे आपने छोड़ दिया है।
sqlite> insert into CRICKETERS (First_Name, Last_Name, Country)
values ('Jonathan', 'Trott', 'SouthAfrica');
sqlite>
आप स्तंभ नामों को निर्दिष्ट किए बिना तालिका में रिकॉर्ड भी डाल सकते हैं, यदि आपके द्वारा पारित मानों का क्रम तालिका में उनके संबंधित स्तंभ नामों के समान है।
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
अभिलेखों को एक तालिका में सम्मिलित करने के बाद आप नीचे दिखाए गए कथन के अनुसार इसकी सामग्री को सत्यापित कर सकते हैं -
sqlite> select * from cricketers;
Shikhar |Dhawan | 33 | Delhi | India
Jonathan |Trott | | | SouthAfrica
Kumara |Sangakkara | 41 | Matale| Srilanka
Virat |Kohli | 30 | Delhi | India
Rohit |Sharma | 32 | Nagpur| India
sqlite>
पायथन का उपयोग करके डेटा सम्मिलित करना
SQLite डेटाबेस में मौजूदा तालिका में रिकॉर्ड जोड़ने के लिए -
Sqlite3 पैकेज आयात करें।
डेटाबेस के नाम को एक पैरामीटर के रूप में पारित करके कनेक्ट () विधि का उपयोग करके एक कनेक्शन ऑब्जेक्ट बनाएं।
cursor()पद्धति एक कर्सर ऑब्जेक्ट लौटाती है जिसका उपयोग करके आप SQLite3 के साथ संवाद कर सकते हैं। (ऊपर बनाई गई) कनेक्शन ऑब्जेक्ट पर कर्सर () ऑब्जेक्ट को आमंत्रित करके एक कर्सर ऑब्जेक्ट बनाएं।
फिर, एक वस्तु के रूप में एक INSERT विवरण पास करके, कर्सर ऑब्जेक्ट पर निष्पादित () विधि को लागू करें।
उदाहरण
अजगर उदाहरण के बाद EMPLOYEE नामक तालिका में रिकॉर्ड सम्मिलित करता है -
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Preparing SQL queries to INSERT a record into the database.
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Ramya', 'Rama Priya', 27, 'F', 9000)'''
)
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Vinay', 'Battacharya', 20, 'M', 6000)''')
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Sharukh', 'Sheik', 25, 'M', 8300)''')
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Sarmista', 'Sharma', 26, 'F', 10000)''')
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Tripthi', 'Mishra', 24, 'F', 6000)''')
# Commit your changes in the database
conn.commit()
print("Records inserted........")
# Closing the connection
conn.close()
उत्पादन
Records inserted........
आप चयन क्वेरी का उपयोग करते हुए SQLite तालिका से डेटा पुनः प्राप्त कर सकते हैं। यह प्रश्न / कथन सारणीबद्ध रूप में निर्दिष्ट संबंध (तालिका) की सामग्री देता है और इसे परिणाम-सेट कहा जाता है।
वाक्य - विन्यास
SQLite में SELECT स्टेटमेंट का सिंटैक्स निम्नलिखित है -
SELECT column1, column2, columnN FROM table_name;
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 5 रिकॉर्ड डाले हैं -
sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
सेलेक्ट क्वेरी के बाद कॉलम FIRST_NAME, LAST_NAME और, CRICKETERS तालिका से COUNTRY का मान प्राप्त करता है।
sqlite> SELECT FIRST_NAME, LAST_NAME, COUNTRY FROM CRICKETERS;
Shikhar |Dhawan |India
Jonathan |Trott |SouthAfrica
Kumara |Sangakkara |Srilanka
Virat |Kohli |India
Rohit |Sharma |India
sqlite>
जैसा कि आप निरीक्षण करते हैं, SQLite डेटाबेस का सेलेक्ट स्टेटमेंट केवल निर्दिष्ट तालिकाओं के रिकॉर्ड लौटाता है। एक स्वरूपित आउटपुट प्राप्त करने के लिए आपको सेट करने की आवश्यकता हैheader, तथा mode नीचे दिए गए चयन के अनुसार संबंधित आदेशों का उपयोग करते हुए -
sqlite> .header on
sqlite> .mode column
sqlite> SELECT FIRST_NAME, LAST_NAME, COUNTRY FROM CRICKETERS;
First_Name Last_Name Country
---------- ---------- ----------
Shikhar Dhawan India
Jonathan Trott SouthAfric
Kumara Sangakkara rilanka
Virat Kohli India
Rohit Sharma India
यदि आप प्रत्येक रिकॉर्ड के सभी स्तंभों को पुनः प्राप्त करना चाहते हैं, तो आपको स्तंभों के नामों को "*" से बदलने की आवश्यकता है जैसा कि नीचे दिखाया गया है -
sqlite> .header on
sqlite> .mode column
sqlite> SELECT * FROM CRICKETERS;
First_Name Last_Name Age Place_Of_Birth Country
---------- ---------- ------- -------------- ----------
Shikhar Dhawan 33 Delhi India
Jonathan Trott 38 CapeTown SouthAfric
Kumara Sangakkara 41 Matale Srilanka
Virat Kohli 30 Delhi India
Rohit Sharma 32 Nagpur India
sqlite>
में SQLite डिफ़ॉल्ट रूप से स्तंभों की चौड़ाई इस चौड़ाई कटा रहे हैं परे 10 मान (2 के देश स्तंभ का पालन है nd उपरोक्त तालिका में पंक्ति)। आप प्रत्येक कॉलम की चौड़ाई को आवश्यक मान पर सेट कर सकते हैं.width कमांड, तालिका की सामग्री को प्राप्त करने से पहले जैसा कि नीचे दिखाया गया है -
sqlite> .width 10, 10, 4, 10, 13
sqlite> SELECT * FROM CRICKETERS;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- --------
Shikhar Dhawan 33 Delhi India
Jonathan Trott 38 CapeTown SouthAfrica
Kumara Sangakkara 41 Matale Srilanka
Virat Kohli 30 Delhi India
Rohit Sharma 32 Nagpur India
sqlite>
पायथन का उपयोग कर डेटा पुनर्प्राप्त करना
किसी भी डेटाबेस पर पढ़ें ऑपरेशन का मतलब डेटाबेस से कुछ उपयोगी जानकारी प्राप्त करना है। आप sqlite अजगर मॉड्यूल द्वारा प्रदान की गई विधि () विधि का उपयोग करके MYSQL से डेटा प्राप्त कर सकते हैं।
Sqlite3.Cursor वर्ग तीन तरीके प्रदान करता है जैसे कि भ्रूण (), fetchmany () और, fetchone () जहां,
भ्रूण () विधि एक क्वेरी के परिणाम सेट में सभी पंक्तियों को पुनः प्राप्त करती है और उन्हें टुपल्स की सूची के रूप में वापस करती है। (यदि हम इसे कुछ पंक्तियों को प्राप्त करने के बाद निष्पादित करते हैं तो यह शेष लोगों को वापस कर देता है)।
भ्रूण () विधि एक क्वेरी के परिणाम में अगली पंक्ति लाती है और इसे एक टुपल के रूप में वापस करती है।
Fetchmany () विधि fetchone () के समान है, लेकिन, यह एक पंक्ति के बजाय किसी क्वेरी के परिणाम सेट में पंक्तियों के अगले सेट को पुनः प्राप्त करता है।
Note - एक परिणाम सेट एक ऑब्जेक्ट है जिसे एक टेबल को क्वेरी करने के लिए कर्सर ऑब्जेक्ट का उपयोग करने पर वापस किया जाता है।
उदाहरण
उदाहरण के बाद EMPLOYEE तालिका की सभी पंक्तियों को SELECT क्वेरी का उपयोग करके और प्रारंभ में प्राप्त परिणाम से, हम भ्रूण () विधि का उपयोग करके पहली पंक्ति को पुनः प्राप्त कर रहे हैं और फिर भ्रूण () विधि का उपयोग करके शेष पंक्तियों को प्राप्त कर रहे हैं।
पायथन कार्यक्रम के बाद पता चलता है कि उपरोक्त उदाहरण में बनाई गई कंपनी तालिका से रिकॉर्ड कैसे प्राप्त करें और प्रदर्शित करें।
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Retrieving data
cursor.execute('''SELECT * from EMPLOYEE''')
#Fetching 1st row from the table
result = cursor.fetchone();
print(result)
#Fetching 1st row from the table
result = cursor.fetchall();
print(result)
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
('Ramya', 'Rama priya', 27, 'F', 9000.0)
[
('Vinay', 'Battacharya', 20, 'M', 6000.0),
('Sharukh', 'Sheik', 25, 'M', 8300.0),
('Sarmista', 'Sharma', 26, 'F', 10000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0)
]
यदि आप SQLite में किसी तालिका की विशेष पंक्तियों को प्राप्त करना, हटाना या अपडेट करना चाहते हैं, तो आपको ऑपरेशन के लिए तालिका की पंक्तियों को फ़िल्टर करने के लिए शर्त निर्दिष्ट करने के लिए जहां क्लॉज का उपयोग करना होगा।
उदाहरण के लिए, यदि आपके पास खंड के साथ एक सेलेक्ट स्टेटमेंट है, तो केवल पंक्तियाँ जो निर्दिष्ट स्थिति को संतुष्ट करती हैं, को पुनः प्राप्त किया जाएगा।
वाक्य - विन्यास
SQLite में WHERE क्लॉज का वाक्य विन्यास निम्नलिखित है -
SELECT column1, column2, columnN
FROM table_name
WHERE [search_condition]
आप तुलना या तार्किक ऑपरेटरों का उपयोग करके एक search_condition निर्दिष्ट कर सकते हैं। जैसे>, <, =, LIKE, NOT, आदि निम्नलिखित उदाहरण इस अवधारणा को स्पष्ट करेंगे।
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 5 रिकॉर्ड डाले हैं -
sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
चयन विवरण के बाद उन अभिलेखों को पुनः प्राप्त किया जाता है जिनकी आयु 35 से अधिक है -
sqlite> SELECT * FROM CRICKETERS WHERE AGE > 35;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- -----------
Jonathan Trott 38 CapeTown SouthAfrica
Kumara Sangakkara 41 Matale Srilanka
sqlite>
जहां क्लाथ पायथन का उपयोग कर रहा है
Cursor ऑब्जेक्ट / क्लास में क्वेरीज़ को निष्पादित करने और डेटा को लाने के लिए सभी तरीके हैं, आदि कनेक्शन क्लास का कर्सर विधि एक कर्सर ऑब्जेक्ट देता है।
इसलिए, अजगर का उपयोग कर SQLite डेटाबेस में एक तालिका बनाने के लिए -
कनेक्ट () विधि का उपयोग करके डेटाबेस के साथ संबंध स्थापित करें।
उपरोक्त बनाई गई कनेक्शन ऑब्जेक्ट पर कर्सर () विधि को लागू करके एक कर्सर ऑब्जेक्ट बनाएं।
अब Cursor वर्ग के निष्पादन () पद्धति का उपयोग करके क्रिएट टेबल स्टेटमेंट को निष्पादित करें।
उदाहरण
उदाहरण के बाद कर्मचारी नाम की एक तालिका बनाता है और उसे पॉप्युलेट करता है। फिर जहां क्लॉज का उपयोग करते हुए यह 23 से कम आयु मान के साथ रिकॉर्ड प्राप्त करता है।
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Doping EMPLOYEE table if already exists.
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
sql = '''CREATE TABLE EMPLOYEE(
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT
)'''
cursor.execute(sql)
#Populating the table
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Ramya', 'Rama priya', 27, 'F', 9000)''')
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Vinay', 'Battacharya', 20, 'M', 6000)''')
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Sharukh', 'Sheik', 25, 'M', 8300)''')
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Sarmista', 'Sharma', 26, 'F', 10000)''')
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Tripthi', 'Mishra', 24, 'F', 6000)''')
#Retrieving specific records using the where clause
cursor.execute("SELECT * from EMPLOYEE WHERE AGE <23")
print(cursor.fetchall())
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
[('Vinay', 'Battacharya', 20, 'M', 6000.0)]
SELECT क्वेरी का उपयोग करके डेटा प्राप्त करते समय, आपको रिकॉर्ड उसी क्रम में मिलेंगे, जिसमें आपने उन्हें सम्मिलित किया है।
आप वांछित क्रम में परिणामों को क्रमबद्ध कर सकते हैं (आरोही या अवरोही) Order Byखंड। डिफ़ॉल्ट रूप से, यह क्लॉज़ आरोही क्रम में परिणाम देता है, यदि आपको उन्हें अवरोही क्रम में व्यवस्थित करने की आवश्यकता है तो आपको "DESC" का स्पष्ट रूप से उपयोग करने की आवश्यकता है।
वाक्य - विन्यास
SQLite में ORDER BY क्लॉज का वाक्य विन्यास निम्नलिखित है।
SELECT column-list
FROM table_name
[WHERE condition]
[ORDER BY column1, column2, .. columnN] [ASC | DESC];
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 5 रिकॉर्ड डाले हैं -
sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
चयनित चयन के बाद उनकी आयु के बढ़ते क्रम में CRICKETERS तालिका की पंक्तियों को पुनः प्राप्त किया जाता है -
sqlite> SELECT * FROM CRICKETERS ORDER BY AGE;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- -----------
Virat Kohli 30 Delhi India
Rohit Sharma 32 Nagpur India
Shikhar Dhawan 33 Delhi India
Jonathan Trott 38 CapeTown SouthAfrica
Kumara Sangakkara 41 Matale Srilanka
sqlite>
तालिका के रिकॉर्ड को सॉर्ट करने के लिए आप एक से अधिक कॉलम का उपयोग कर सकते हैं। सेलेक्ट स्टेटमेंट्स के बाद कॉलम AGE और FIRST_NAME के आधार पर CRICKETERS तालिका के रिकॉर्ड को सॉर्ट करें ।
sqlite> SELECT * FROM CRICKETERS ORDER BY AGE, FIRST_NAME;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- -------------
Virat Kohli 30 Delhi India
Rohit Sharma 32 Nagpur India
Shikhar Dhawan 33 Delhi India
Jonathan Trott 38 CapeTown SouthAfrica
Kumara Sangakkara 41 Matale Srilanka
sqlite>
डिफ़ॉल्ट रूप से, ORDER BY खण्ड आरोही क्रम में एक तालिका के अभिलेखों को क्रमबद्ध करता है आप DESC का उपयोग करके अवरोही क्रम में परिणाम की व्यवस्था कर सकते हैं -
sqlite> SELECT * FROM CRICKETERS ORDER BY AGE DESC;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- -------------
Kumara Sangakkara 41 Matale Srilanka
Jonathan Trott 38 CapeTown SouthAfrica
Shikhar Dhawan 33 Delhi India
Rohit Sharma 32 Nagpur India
Virat Kohli 30 Delhi India
sqlite>
अजगर का उपयोग करके खंड द्वारा आदेश
विशिष्ट क्रम में एक तालिका की सामग्री को पुनः प्राप्त करने के लिए, कर्सर ऑब्जेक्ट पर निष्पादित () विधि का आह्वान करें और, ORDER BY खंड के साथ SELECT स्टेटमेंट को इसके पैरामीटर के रूप में पास करें।
उदाहरण
निम्नलिखित उदाहरण में हम नाम और कर्मचारी के साथ एक तालिका बना रहे हैं, इसे पॉप्युलेट कर रहे हैं, और अपने रिकॉर्ड को उनकी उम्र के (आरोही) क्रम में वापस लाकर ORDER BY खंड का उपयोग कर रहे हैं।
import psycopg2
#establishing the connection
conn = psycopg2.connect(
database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)
#Setting auto commit false
conn.autocommit = True
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Doping EMPLOYEE table if already exists.
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
#Creating a table
sql = '''CREATE TABLE EMPLOYEE(
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT, SEX CHAR(1),
INCOME INT,
CONTACT INT
)'''
cursor.execute(sql)
#Populating the table
#Populating the table
cursor.execute(
'''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Ramya', 'Rama priya', 27, 'F', 9000),
('Vinay', 'Battacharya', 20, 'M', 6000),
('Sharukh', 'Sheik', 25, 'M', 8300),
('Sarmista', 'Sharma', 26, 'F', 10000),
('Tripthi', 'Mishra', 24, 'F', 6000)''')
conn.commit()
#Retrieving specific records using the ORDER BY clause
cursor.execute("SELECT * from EMPLOYEE ORDER BY AGE")
print(cursor.fetchall())
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
[
('Vinay', 'Battacharya', 20, 'M', 6000, None),
('Tripthi', 'Mishra', 24, 'F', 6000, None),
('Sharukh', 'Sheik', 25, 'M', 8300, None),
('Sarmista', 'Sharma', 26, 'F', 10000, None),
('Ramya', 'Rama priya', 27, 'F', 9000, None)
]
किसी भी डेटाबेस पर अद्यतन ऑपरेशन का तात्पर्य तालिका के एक या एक से अधिक रिकॉर्ड के मानों को संशोधित करना है, जो पहले से ही डेटाबेस में उपलब्ध हैं। आप UPDATE कथन का उपयोग करते हुए SQLite में मौजूदा रिकॉर्ड के मूल्यों को अपडेट कर सकते हैं।
विशिष्ट पंक्तियों को अपडेट करने के लिए, आपको इसके साथ WHERE क्लॉज़ का उपयोग करना होगा।
वाक्य - विन्यास
SQLite में अद्यतन कथन का वाक्य विन्यास निम्नलिखित है -
UPDATE table_name
SET column1 = value1, column2 = value2...., columnN = valueN
WHERE [condition];
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 5 रिकॉर्ड डाले हैं -
sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
निम्नलिखित कथन क्रिकेटर की आयु को संशोधित करता है, जिसका पहला नाम है Shikhar -
sqlite> UPDATE CRICKETERS SET AGE = 45 WHERE FIRST_NAME = 'Shikhar' ;
sqlite>
यदि आप उस रिकॉर्ड को पुनः प्राप्त करते हैं जिसका FIRST_NAME शिखर है, तो आप देखते हैं कि आयु मान 45 में बदल दिया गया है -
sqlite> SELECT * FROM CRICKETERS WHERE FIRST_NAME = 'Shikhar';
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- --------
Shikhar Dhawan 45 Delhi India
sqlite>
यदि आपने WHERE के खंड का उपयोग नहीं किया है, तो सभी रिकॉर्ड के मान अपडेट किए जाएंगे। UPDATE के बयान के बाद CRICKETERS तालिका में सभी रिकॉर्डों की आयु 1 से बढ़ जाती है -
sqlite> UPDATE CRICKETERS SET AGE = AGE+1;
sqlite>
यदि आप SELECT कमांड का उपयोग करके तालिका की सामग्री को पुनः प्राप्त करते हैं, तो आप अद्यतन मानों को देख सकते हैं -
sqlite> SELECT * FROM CRICKETERS;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- -------------
Shikhar Dhawan 46 Delhi India
Jonathan Trott 39 CapeTown SouthAfrica
Kumara Sangakkara 42 Matale Srilanka
Virat Kohli 31 Delhi India
Rohit Sharma 33 Nagpur India
sqlite>
पायथन का उपयोग करके मौजूदा रिकॉर्ड को अद्यतन करना
SQLite डेटाबेस में मौजूदा तालिका में रिकॉर्ड जोड़ने के लिए -
Sqlite3 पैकेज आयात करें।
डेटाबेस के नाम को एक पैरामीटर के रूप में पारित करके कनेक्ट () विधि का उपयोग करके एक कनेक्शन ऑब्जेक्ट बनाएं।
cursor()पद्धति एक कर्सर ऑब्जेक्ट लौटाती है जिसका उपयोग करके आप SQLite3 के साथ संवाद कर सकते हैं। (ऊपर बनाई गई) कनेक्शन ऑब्जेक्ट पर कर्सर () ऑब्जेक्ट को आमंत्रित करके एक कर्सर ऑब्जेक्ट बनाएं।
फिर, कर्सर ऑब्जेक्ट पर निष्पादित () विधि को एक पैरामीटर के रूप में एक अद्यतन विवरण पारित करके आह्वान करें।
उदाहरण
पायथन उदाहरण के बाद, EMPLOYEE नाम से एक तालिका बनाता है, इसमें 5 रिकॉर्ड सम्मिलित करता है और, सभी पुरुष कर्मचारियों की आयु 1 से बढ़ा देता है -
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Doping EMPLOYEE table if already exists.
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
#Creating table as per requirement
sql ='''CREATE TABLE EMPLOYEE(
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT
)'''
cursor.execute(sql)
#Inserting data
cursor.execute('''INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Ramya', 'Rama priya', 27, 'F', 9000),
('Vinay', 'Battacharya', 20, 'M', 6000),
('Sharukh', 'Sheik', 25, 'M', 8300),
('Sarmista', 'Sharma', 26, 'F', 10000),
('Tripthi', 'Mishra', 24, 'F', 6000)''')
conn.commit()
#Fetching all the rows before the update
print("Contents of the Employee table: ")
cursor.execute('''SELECT * from EMPLOYEE''')
print(cursor.fetchall())
#Updating the records
sql = '''UPDATE EMPLOYEE SET AGE=AGE+1 WHERE SEX = 'M' '''
cursor.execute(sql)
print("Table updated...... ")
#Fetching all the rows after the update
print("Contents of the Employee table after the update operation: ")
cursor.execute('''SELECT * from EMPLOYEE''')
print(cursor.fetchall())
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
Contents of the Employee table:
[
('Ramya', 'Rama priya', 27, 'F', 9000.0),
('Vinay', 'Battacharya', 20, 'M', 6000.0),
('Sharukh', 'Sheik', 25, 'M', 8300.0),
('Sarmista', 'Sharma', 26, 'F', 10000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0)
]
Table updated......
Contents of the Employee table after the update operation:
[
('Ramya', 'Rama priya', 27, 'F', 9000.0),
('Vinay', 'Battacharya', 21, 'M', 6000.0),
('Sharukh', 'Sheik', 26, 'M', 8300.0),
('Sarmista', 'Sharma', 26, 'F', 10000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0)
]
SQLite तालिका से रिकॉर्ड हटाने के लिए, आपको DELETE FROM कथन का उपयोग करने की आवश्यकता है। विशिष्ट रिकॉर्ड को निकालने के लिए, आपको इसके साथ WHERE क्लॉज़ का उपयोग करना होगा।
वाक्य - विन्यास
SQLite में DELETE क्वेरी का सिंटैक्स निम्नलिखित है -
DELETE FROM table_name [WHERE Clause]
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 5 रिकॉर्ड डाले हैं -
sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
निम्नलिखित कथन से उस क्रिकेटर का रिकॉर्ड हटा दिया जाता है जिसका अंतिम नाम 'संगकारा' है।
sqlite> DELETE FROM CRICKETERS WHERE LAST_NAME = 'Sangakkara';
sqlite>
यदि आप SELECT स्टेटमेंट का उपयोग करके तालिका की सामग्री को पुनः प्राप्त करते हैं, तो आप केवल 4 रिकॉर्ड देख सकते हैं क्योंकि हमने एक को हटा दिया है।
sqlite> SELECT * FROM CRICKETERS;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- --------
Shikhar Dhawan 46 Delhi India
Jonathan Trott 39 CapeTown SouthAfrica
Virat Kohli 31 Delhi India
Rohit Sharma 33 Nagpur India
sqlite>
यदि आप WH कथन के बिना DELETE FROM कथन को निष्पादित करते हैं, तो निर्दिष्ट तालिका से सभी रिकॉर्ड हटा दिए जाएंगे।
sqlite> DELETE FROM CRICKETERS;
sqlite>
चूंकि आपने सभी रिकॉर्ड हटा दिए हैं, अगर आप CRICKETERS तालिका की सामग्री को पुनः प्राप्त करने का प्रयास करते हैं, तो SELECT स्टेटमेंट का उपयोग करके आपको नीचे दिखाए गए अनुसार एक खाली परिणाम सेट मिलेगा -
sqlite> SELECT * FROM CRICKETERS;
sqlite>
पायथन का उपयोग करके डेटा हटाना
SQLite डेटाबेस में मौजूदा तालिका में रिकॉर्ड जोड़ने के लिए -
Sqlite3 पैकेज आयात करें।
डेटाबेस के नाम को एक पैरामीटर के रूप में पारित करके कनेक्ट () विधि का उपयोग करके एक कनेक्शन ऑब्जेक्ट बनाएं ।
cursor()पद्धति एक कर्सर ऑब्जेक्ट लौटाती है जिसका उपयोग करके आप SQLite3 के साथ संवाद कर सकते हैं। (ऊपर बनाई गई) कनेक्शन ऑब्जेक्ट पर कर्सर () ऑब्जेक्ट को आमंत्रित करके एक कर्सर ऑब्जेक्ट बनाएं।
फिर, कर्सर ऑब्जेक्ट पर एग्जीक्यूट () विधि को लागू करें, पास करके DELETE एक पैरामीटर के रूप में बयान।
उदाहरण
पायथन उदाहरण के बाद EMPLOYEE तालिका के रिकॉर्ड को 25 से अधिक आयु मान के साथ हटा दिया जाता है।
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Retrieving contents of the table
print("Contents of the table: ")
cursor.execute('''SELECT * from EMPLOYEE''')
print(cursor.fetchall())
#Deleting records
cursor.execute('''DELETE FROM EMPLOYEE WHERE AGE > 25''')
#Retrieving data after delete
print("Contents of the table after delete operation ")
cursor.execute("SELECT * from EMPLOYEE")
print(cursor.fetchall())
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
Contents of the table:
[
('Ramya', 'Rama priya', 27, 'F', 9000.0),
('Vinay', 'Battacharya', 21, 'M', 6000.0),
('Sharukh', 'Sheik', 26, 'M', 8300.0),
('Sarmista', 'Sharma', 26, 'F', 10000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0)
]
Contents of the table after delete operation
[
('Vinay', 'Battacharya', 21, 'M', 6000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0)
]
आप DROP TABLE स्टेटमेंट का उपयोग करके एक पूरी तालिका निकाल सकते हैं। आपको केवल उस तालिका का नाम निर्दिष्ट करना होगा जिसे आपको हटाने की आवश्यकता है।
वाक्य - विन्यास
PostgreSQL में DROP टेबल स्टेटमेंट का सिंटैक्स निम्नलिखित है -
DROP TABLE table_name;
उदाहरण
मान लें कि हमने निम्नलिखित प्रश्नों का उपयोग करके CRICKETERS और EMPLOYEES नाम से दो तालिकाएँ बनाई हैं -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int,
Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
sqlite> CREATE TABLE EMPLOYEE(
FIRST_NAME CHAR(20) NOT NULL, LAST_NAME CHAR(20), AGE INT,
SEX CHAR(1), INCOME FLOAT
);
sqlite>
अब यदि आप तालिकाओं की सूची का उपयोग करके सत्यापित करते हैं .tables कमांड, आप ऊपर दी गई सारणी को इस रूप में देख सकते हैं (सूची) -
sqlite> .tables
CRICKETERS EMPLOYEE
sqlite>
निम्नलिखित कथन डेटाबेस से कर्मचारी नाम की तालिका को हटाता है -
sqlite> DROP table employee;
sqlite>
चूंकि आपने कर्मचारी तालिका को हटा दिया है, यदि आप फिर से तालिकाओं की सूची प्राप्त करते हैं, तो आप इसमें केवल एक तालिका का निरीक्षण कर सकते हैं।
sqlite> .tables
CRICKETERS
sqlite>
यदि आप कर्मचारी तालिका को फिर से हटाने की कोशिश करते हैं, क्योंकि आपने पहले ही इसे हटा दिया है, तो आपको यह कहते हुए एक त्रुटि मिलेगी कि "ऐसी कोई तालिका" नहीं दिखाई गई है -
sqlite> DROP table employee;
Error: no such table: employee
sqlite>
इसे हल करने के लिए, आप DELETE स्टेटमेंट के साथ IF EXISTS क्लॉज का उपयोग कर सकते हैं। यह तालिका को हटा देता है यदि यह मौजूद है तो DELETE ऑपरेशन को छोड़ देता है।
sqlite> DROP table IF EXISTS employee;
sqlite>
अजगर का उपयोग करते हुए एक टेबल गिराना
MYSQL के DROP स्टेटमेंट का उपयोग करके, जब भी आपको आवश्यकता हो, आप एक टेबल को ड्रॉप कर सकते हैं, लेकिन किसी भी मौजूदा टेबल को डिलीट करते समय आपको बहुत सावधानी बरतने की आवश्यकता है क्योंकि किसी टेबल को हटाने के बाद खोए गए डेटा को रिकवर नहीं किया जाएगा।
उदाहरण
अजगर का उपयोग कर SQLite3 डेटाबेस से एक तालिका ड्रॉप करने के लिए execute() कर्सर ऑब्जेक्ट पर विधि और ड्रॉप स्टेटमेंट को एक पैरामीटर के रूप में पास करें।
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Doping EMPLOYEE table if already exists
cursor.execute("DROP TABLE emp")
print("Table dropped... ")
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
Table dropped...
रिकॉर्ड प्राप्त करते समय यदि आप उन्हें किसी विशेष संख्या द्वारा सीमित करना चाहते हैं, तो आप ऐसा कर सकते हैं, SQLite के लिमट क्लॉज का उपयोग करके।
वाक्य - विन्यास
निम्नलिखित SQLite में सीमा खंड का सिंटैक्स है -
SELECT column1, column2, columnN
FROM table_name
LIMIT [no of rows]
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 5 रिकॉर्ड डाले हैं -
sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
निम्नलिखित कथन लिमिट क्लॉज का उपयोग करके क्रिकेटरों की तालिका के पहले 3 रिकॉर्ड्स को पुनः प्राप्त करता है -
sqlite> SELECT * FROM CRICKETERS LIMIT 3;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- -------------
Shikhar Dhawan 33 Delhi India
Jonathan Trott 38 CapeTown SouthAfrica
Kumara Sangakkara 41 Matale Srilanka
sqlite>
यदि आपको nth रिकॉर्ड (1 सेंट नहीं ) से शुरू होने वाले रिकॉर्ड को सीमित करने की आवश्यकता है , तो आप ऐसा कर सकते हैं, लिफ़िट के साथ OFFSET का उपयोग कर सकते हैं।
sqlite> SELECT * FROM CRICKETERS LIMIT 3 OFFSET 2;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- --------
Kumara Sangakkara 41 Matale Srilanka
Virat Kohli 30 Delhi India
Rohit Sharma 32 Nagpur India
sqlite>
पायथन का उपयोग करके सीमा खंड
यदि आप लिमिट क्लॉज के साथ सेलेक्ट क्वेरी को पास करके कर्सर ऑब्जेक्ट पर एग्जीक्यूट () विधि को लागू करते हैं, तो आप आवश्यक संख्या में रिकॉर्ड पुनः प्राप्त कर सकते हैं।
उदाहरण
पायथन उदाहरण के बाद लिमाट क्लॉज का उपयोग करते हुए EMPLOYEE तालिका के पहले दो रिकॉर्ड प्राप्त करता है।
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Retrieving single row
sql = '''SELECT * from EMPLOYEE LIMIT 3'''
#Executing the query
cursor.execute(sql)
#Fetching the data
result = cursor.fetchall();
print(result)
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
[
('Ramya', 'Rama priya', 27, 'F', 9000.0),
('Vinay', 'Battacharya', 20, 'M', 6000.0),
('Sharukh', 'Sheik', 25, 'M', 8300.0)
]
जब आपने डेटा को दो तालिकाओं में विभाजित किया है, तो आप इन दो तालिकाओं से जोड़ों का उपयोग करके संयुक्त रिकॉर्ड प्राप्त कर सकते हैं।
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
आइए हम CRICKETERS तालिका में प्रत्येक खिलाड़ी के वन-डे क्रिकेट आंकड़ों का वर्णन करते हुए एक और तालिका OdiStats बनाएं।
sqlite> CREATE TABLE ODIStats (
First_Name VARCHAR(255),
Matches INT,
Runs INT,
AVG FLOAT,
Centuries INT,
HalfCenturies INT
);
sqlite>
निम्नलिखित कथन इन दो तालिकाओं में मूल्यों के संयोजन डेटा को पुनः प्राप्त करता है -
sqlite> SELECT
Cricketers.First_Name, Cricketers.Last_Name, Cricketers.Country,
OdiStats.matches, OdiStats.runs, OdiStats.centuries, OdiStats.halfcenturies
from Cricketers INNER JOIN OdiStats ON Cricketers.First_Name = OdiStats.First_Name;
First_Name Last_Name Country Matches Runs Centuries HalfCenturies
---------- ---------- ------- ------- ---- --------- --------------
Shikhar Dhawan Indi 133 5518 17 27
Jonathan Trott Sout 68 2819 4 22
Kumara Sangakkara Sril 404 14234 25 93
Virat Kohli Indi 239 11520 43 54
Rohit Sharma Indi 218 8686 24 42
sqlite>
पायथन का उपयोग करके क्लॉज से जुड़ें
SQLite उदाहरण के बाद, अजगर का उपयोग करते हुए JOIN क्लॉज प्रदर्शित करता है -
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Retrieving data
sql = '''SELECT * from EMP INNER JOIN CONTACT ON EMP.CONTACT = CONTACT.ID'''
#Executing the query
cursor.execute(sql)
#Fetching 1st row from the table
result = cursor.fetchall();
print(result)
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
उत्पादन
[
('Ramya', 'Rama priya', 27, 'F', 9000.0, 101, 101, '[email protected]', 'Hyderabad'),
('Vinay', 'Battacharya', 20, 'M', 6000.0, 102, 102,'[email protected]', 'Vishakhapatnam'),
('Sharukh', 'Sheik', 25, 'M', 8300.0, 103, 103, '[email protected]', 'Pune'),
('Sarmista', 'Sharma', 26, 'F', 10000.0, 104, 104, '[email protected]', 'Mumbai')
]
Sqlite3.Cursor वर्ग एक उदाहरण है जिसके उपयोग से आप SQLite स्टेटमेंट्स को निष्पादित करने वाले तरीकों को लागू कर सकते हैं, प्रश्नों के परिणाम सेट से डेटा प्राप्त कर सकते हैं। आप कनेक्शन ऑब्जेक्ट / वर्ग के कर्सर () विधि का उपयोग करके कर्सर ऑब्जेक्ट बना सकते हैं।
उदाहरण
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
तरीकों
निम्नलिखित विभिन्न तरीके Cursor वर्ग / वस्तु द्वारा प्रदान किए गए हैं।
तरीका | विवरण |
---|---|
निष्पादित() | यह रूटीन SQL कथन निष्पादित करता है। SQL स्टेटमेंट को पैरामीटराइज़ किया जा सकता है (यानी, एसक्यूएल शाब्दिक के बजाय प्लेसहोल्डर)। Psycopg2 मॉड्यूल% s साइन का उपयोग करके प्लेसहोल्डर का समर्थन करता है उदाहरण के लिए: RPG.execute ("लोगों के मानों में डालें (% s,% s)", (जो, आयु) |
executemany () | यह दिनचर्या अनुक्रम sql में पाए जाने वाले सभी पैरामीटर अनुक्रमों या मैपिंग के विरुद्ध SQL कमांड निष्पादित करता है। |
fetchone () | यह पद्धति एक क्वेरी अनुक्रम सेट की अगली पंक्ति लाती है, एक एकल अनुक्रम लौटाती है, या जब कोई अधिक डेटा उपलब्ध नहीं होता है। |
fetchmany () | यह दिनचर्या एक प्रश्न परिणाम की पंक्तियों के अगले सेट को लाती है, एक सूची लौटाती है। कोई और पंक्तियाँ उपलब्ध नहीं होने पर एक खाली सूची दी जाती है। विधि आकार पैरामीटर द्वारा इंगित के रूप में कई पंक्तियों को लाने की कोशिश करती है। |
fetchall () | यह रूटीन क्वेरी परिणाम की सभी (शेष) पंक्तियों को एक सूची में लाती है। कोई पंक्तियाँ उपलब्ध नहीं होने पर एक खाली सूची दी जाती है। |
गुण
निम्नलिखित कर्सर श्रेणी के गुण हैं -
तरीका | विवरण |
---|---|
arraySize | यह एक पढ़ने / लिखने की संपत्ति है आप भ्रूण () विधि द्वारा लौटी पंक्तियों की संख्या निर्धारित कर सकते हैं। |
विवरण | यह एक रीड ओनली प्रॉपर्टी है, जो रिजल्ट-सेट में कॉलम के विवरण वाली सूची लौटाती है। |
lastrowid | यह एक रीड ओनली प्रॉपर्टी है, यदि तालिका में कोई भी ऑटो-इन्क्रिमेटेड कॉलम हैं, तो यह उस कॉलम के लिए उत्पन्न मूल्य को पिछले INSERT या, UPDATE ऑपरेशन में लौटाता है। |
पंक्ति गिनती | यह SELECT और UPDATE ऑपरेशन की स्थिति में लौटी / अपडेट की गई पंक्तियों की संख्या लौटाता है। |
संबंध | यह केवल पढ़ने के लिए विशेषता Cursor ऑब्जेक्ट द्वारा उपयोग किए गए SQLite डेटाबेस कनेक्शन प्रदान करता है। |