अजगर PostgreSQL - डेटा हटाएं
आप किसी मौजूदा तालिका में रिकॉर्ड का उपयोग करके हटा सकते हैं DELETE FROMPostgreSQL डेटाबेस का विवरण। विशिष्ट रिकॉर्ड को निकालने के लिए, आपको इसके साथ WHERE क्लॉज़ का उपयोग करना होगा।
वाक्य - विन्यास
PostgreSQL में DELETE क्वेरी का सिंटैक्स निम्नलिखित है -
DELETE FROM table_name [WHERE Clause]
उदाहरण
मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -
postgres=# CREATE TABLE CRICKETERS (
First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int,
Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
CREATE TABLE
postgres=#
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 5 रिकॉर्ड डाले हैं -
postgres=# insert into CRICKETERS values ('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1
निम्नलिखित कथन से उस क्रिकेटर का रिकॉर्ड नष्ट हो जाता है जिसका अंतिम नाम 'संगकारा' है।
postgres=# DELETE FROM CRICKETERS WHERE LAST_NAME = 'Sangakkara';
DELETE 1
यदि आप SELECT स्टेटमेंट का उपयोग करके तालिका की सामग्री को पुनः प्राप्त करते हैं, तो आप केवल 4 रिकॉर्ड देख सकते हैं क्योंकि हमने एक को हटा दिया है।
postgres=# SELECT * FROM CRICKETERS;
first_name | last_name | age | place_of_birth | country
------------+-----------+-----+----------------+-------------
Jonathan | Trott | 39 | CapeTown | SouthAfrica
Virat | Kohli | 31 | Delhi | India
Rohit | Sharma | 33 | Nagpur | India
Shikhar | Dhawan | 46 | Delhi | India
(4 rows)
यदि आप WHET क्लॉज के बिना DELETE FROM स्टेटमेंट को निष्पादित करते हैं, तो निर्दिष्ट तालिका से सभी रिकॉर्ड हटा दिए जाएंगे।
postgres=# DELETE FROM CRICKETERS;
DELETE 4
चूंकि आपने सभी रिकॉर्ड हटा दिए हैं, अगर आप CRICKETERS तालिका की सामग्री को पुनः प्राप्त करने का प्रयास करते हैं, तो SELECT स्टेटमेंट का उपयोग करके आपको नीचे दिखाए गए अनुसार एक खाली परिणाम सेट मिलेगा -
postgres=# SELECT * FROM CRICKETERS;
first_name | last_name | age | place_of_birth | country
------------+-----------+-----+----------------+---------
(0 rows)
पायथन का उपयोग करके डेटा हटाना
Psycopg2 का कर्सर वर्ग नाम निष्पादित () विधि के साथ एक विधि प्रदान करता है। यह विधि क्वेरी को एक पैरामीटर के रूप में स्वीकार करती है और इसे निष्पादित करती है।
इसलिए, अजगर का उपयोग करके PostgreSQL में एक तालिका में डेटा सम्मिलित करने के लिए -
आयात psycopg2 पैकेज।
का उपयोग कर एक कनेक्शन ऑब्जेक्ट बनाएँ connect() विधि, उपयोगकर्ता नाम, पासवर्ड, होस्ट (वैकल्पिक डिफ़ॉल्ट: लोकलहोस्ट) और, डेटाबेस (वैकल्पिक) को इसके मापदंडों के रूप में पारित करके।
विशेषता के मान के रूप में गलत सेट करके ऑटो-कम मोड को बंद करें autocommit।
cursor() की विधि Connectionpsycopg2 लाइब्रेरी का क्लास एक कर्सर ऑब्जेक्ट देता है। इस पद्धति का उपयोग करके एक कर्सर ऑब्जेक्ट बनाएं।
फिर, इसे निष्पादित () विधि के लिए एक पैरामीटर के रूप में पास करके DELETE विवरण निष्पादित करें।
उदाहरण
निम्नलिखित पायथन कोड 25 से अधिक उम्र के मूल्यों के साथ EMPLOYEE तालिका के रिकॉर्ड को हटाता है -
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()
#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),
('Sarmista', 'Sharma', 26, 'F', 10000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0),
('Vinay', 'Battacharya', 21, 'M', 6000.0),
('Sharukh', 'Sheik', 26, 'M', 8300.0)
]
Contents of the table after delete operation:
[
('Tripthi', 'Mishra', 24, 'F', 6000.0),
('Vinay', 'Battacharya', 21, 'M', 6000.0)
]