Menggunakan DELETE Expression
Pada bab sebelumnya, kita telah memahami apa itu Updateekspresi tidak. Ekspresi selanjutnya yang akan kita pelajari adalahDelete.
Operasi delete dapat dilakukan dengan menjalankan metode delete () pada objek tabel target seperti yang diberikan dalam pernyataan berikut -
stmt = students.delete()
Dalam kasus tabel siswa, baris kode di atas membangun ekspresi SQL sebagai berikut -
'DELETE FROM students'
Namun, ini akan menghapus semua baris dalam tabel siswa. Biasanya kueri DELETE dikaitkan dengan ekspresi logis yang ditentukan oleh klausa WHERE. Pernyataan berikut menunjukkan di mana parameter -
stmt = students.delete().where(students.c.id > 2)
Ekspresi SQL yang dihasilkan akan memiliki parameter terikat yang akan diganti saat runtime saat pernyataan dijalankan.
'DELETE FROM students WHERE students.id > :id_1'
Contoh kode berikut akan menghapus baris tersebut dari tabel siswa yang memiliki nama belakang sebagai 'Khanna' -
from sqlalchemy.sql.expression import update
from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()
students = Table(
'students', meta,
Column('id', Integer, primary_key = True),
Column('name', String),
Column('lastname', String),
)
conn = engine.connect()
stmt = students.delete().where(students.c.lastname == 'Khanna')
conn.execute(stmt)
s = students.select()
conn.execute(s).fetchall()
Untuk memverifikasi hasil, segarkan tampilan data tabel siswa di SQLiteStudio.