पायथन SQLite - अद्यतन तालिका
किसी भी डेटाबेस पर अद्यतन ऑपरेशन का तात्पर्य तालिका के एक या एक से अधिक रिकॉर्ड के मानों को संशोधित करना है, जो पहले से ही डेटाबेस में उपलब्ध हैं। आप 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)]