Python MySQL - Verileri Sil
Bir MySQL tablosundaki kayıtları silmek için, DELETE FROMBeyan. Belirli kayıtları kaldırmak için, onunla birlikte WHERE cümlesini kullanmanız gerekir.
Sözdizimi
MYSQL'de DELETE sorgusunun sözdizimi aşağıdadır -
DELETE FROM table_name [WHERE Clause]
Misal
MySQL'de EMPLOYEES adında bir tablo oluşturduğumuzu varsayalım -
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)
Ve INSERT ifadelerini kullanarak 4 kayıt eklediysek -
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 ifadesinin ardından, çalışanın FIRST_NAME ”Mac” ile kaydını siler .
mysql> DELETE FROM EMPLOYEE WHERE FIRST_NAME = 'Mac';
Query OK, 1 row affected (0.12 sec)
Tablonun içeriğini geri alırsanız, birini sildiğimiz için sadece 3 kayıt görebilirsiniz.
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)
DELETE deyimini WHERE yan tümcesi olmadan yürütürseniz, belirtilen tablodaki tüm kayıtlar silinecektir.
mysql> DELETE FROM EMPLOYEE;
Query OK, 3 rows affected (0.09 sec)
Tablonun içeriğini geri alırsanız, aşağıda gösterildiği gibi boş bir set alacaksınız -
mysql> select * from EMPLOYEE;
Empty set (0.00 sec)
Python Kullanarak Bir Tablonun Kayıtlarını Kaldırma
Veritabanınızdan bazı kayıtları silmek istediğinizde DELETE işlemi gereklidir.
Bir tablodaki kayıtları silmek için -
ithalat mysql.connector paketi.
Kullanarak bir bağlantı nesnesi oluşturun mysql.connector.connect() yöntem, kullanıcı adını, parolayı, ana bilgisayarı (isteğe bağlı varsayılan: localhost) ve veritabanını (isteğe bağlı) parametre olarak ona ileterek.
Yukarıda oluşturulan bağlantı nesnesinde cursor () yöntemini çağırarak bir imleç nesnesi oluşturun.
Ardından, DELETE ifadesini parametre olarak ileterek execute() yöntem.
Misal
Aşağıdaki program, YAŞI 20'nin üzerinde olan ÇALIŞAN'dan tüm kayıtları siler -
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()
Çıktı
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)
]