पायथन MySQL - डेटा हटाएं
MySQL टेबल से रिकॉर्ड हटाने के लिए, आपको उपयोग करने की आवश्यकता है DELETE FROMबयान। विशिष्ट रिकॉर्ड को निकालने के लिए, आपको इसके साथ WHERE क्लॉज़ का उपयोग करना होगा।
वाक्य - विन्यास
MYSQL में DELETE क्वेरी का सिंटैक्स निम्नलिखित है -
DELETE FROM table_name [WHERE Clause]
उदाहरण
मान लें कि हमने MySQL में एक तालिका बनाई है जिसका नाम EMPLOYEES है -
mysql> CREATE TABLE EMPLOYEE(
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT
);
Query OK, 0 rows affected (0.36 sec)
और अगर हमने INSERT कथनों का उपयोग करते हुए इसमें 4 रिकॉर्ड डाले हैं -
mysql> INSERT INTO EMPLOYEE VALUES
('Krishna', 'Sharma', 19, 'M', 2000),
('Raj', 'Kandukuri', 20, 'M', 7000),
('Ramya', 'Ramapriya', 25, 'F', 5000),
('Mac', 'Mohan', 26, 'M', 2000);
MySQL स्टेटमेंट के बाद FIRST_NAME "Mac" के साथ कर्मचारी का रिकॉर्ड हटा दिया जाता है ।
mysql> DELETE FROM EMPLOYEE WHERE FIRST_NAME = 'Mac';
Query OK, 1 row affected (0.12 sec)
यदि आप तालिका की सामग्री को पुनः प्राप्त करते हैं, तो आप केवल 3 रिकॉर्ड देख सकते हैं क्योंकि हमने एक हटा दिया है।
mysql> select * from EMPLOYEE;
+------------+-----------+------+------+--------+
| FIRST_NAME | LAST_NAME | AGE | SEX | INCOME |
+------------+-----------+------+------+--------+
| Krishna | Sharma | 20| M | 2000 |
| Raj | Kandukuri | 21| M | 7000 |
| Ramya | Ramapriya | 25| F | 5000 |
+------------+-----------+------+------+--------+
3 rows in set (0.00 sec)
यदि आप WHET खंड के बिना DELETE कथन को निष्पादित करते हैं, तो निर्दिष्ट तालिका से सभी रिकॉर्ड हटा दिए जाएंगे।
mysql> DELETE FROM EMPLOYEE;
Query OK, 3 rows affected (0.09 sec)
यदि आप तालिका की सामग्री प्राप्त करते हैं, तो आपको नीचे दिखाया गया एक खाली सेट मिलेगा -
mysql> select * from EMPLOYEE;
Empty set (0.00 sec)
पायथन का उपयोग कर एक टेबल के रिकॉर्ड को हटाना
DELETE ऑपरेशन की आवश्यकता तब होती है जब आप अपने डेटाबेस से कुछ रिकॉर्ड हटाना चाहते हैं।
तालिका में रिकॉर्ड हटाने के लिए -
आयात mysql.connector पैकेज।
का उपयोग कर एक कनेक्शन ऑब्जेक्ट बनाएँ mysql.connector.connect() विधि, उपयोगकर्ता नाम, पासवर्ड, होस्ट (वैकल्पिक डिफ़ॉल्ट: लोकलहोस्ट) और, डेटाबेस (वैकल्पिक) को इसके मापदंडों के रूप में पारित करके।
ऊपर बनाई गई कनेक्शन ऑब्जेक्ट पर कर्सर () विधि को लागू करके एक कर्सर ऑब्जेक्ट बनाएं।
फिर, निष्पादित करें DELETE यह एक पैरामीटर के रूप में पारित करके बयान execute() तरीका।
उदाहरण
निम्नलिखित कार्यक्रम EMPLOYEE से सभी रिकॉर्ड को हटा देता है जिसका AGE 20 से अधिक है -
import mysql.connector
#establishing the connection
conn = mysql.connector.connect(
user='root', password='password', host='127.0.0.1', database='mydb'
)
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Retrieving single row
print("Contents of the table: ")
cursor.execute("SELECT * from EMPLOYEE")
print(cursor.fetchall())
#Preparing the query to delete records
sql = "DELETE FROM EMPLOYEE WHERE AGE > '%d'" % (25)
try:
# Execute the SQL command
cursor.execute(sql)
# Commit your changes in the database
conn.commit()
except:
# Roll back in case there is any error
conn.rollback()
#Retrieving data
print("Contents of the table after delete operation ")
cursor.execute("SELECT * from EMPLOYEE")
print(cursor.fetchall())
#Closing the connection
conn.close()
उत्पादन
Contents of the table:
[
('Krishna', 'Sharma', 22, 'M', 2000.0),
('Raj', 'Kandukuri', 23, 'M', 7000.0),
('Ramya', 'Ramapriya', 26, 'F', 5000.0),
('Mac', 'Mohan', 20, 'M', 2000.0),
('Ramya', 'Rama priya', 27, 'F', 9000.0)
]
Contents of the table after delete operation:
[
('Krishna', 'Sharma', 22, 'M', 2000.0),
('Raj', 'Kandukuri', 23, 'M', 7000.0),
('Mac', 'Mohan', 20, 'M', 2000.0)
]