В предыдущей главе мы поняли, что делает выражение Update . Следующее выражение, которое мы собираемся выучить, это Delete .
Операция удаления может быть выполнена путем запуска метода delete () для объекта целевой таблицы, как указано в следующем операторе:
stmt = students.delete()
В случае таблицы студентов приведенная выше строка кода создает выражение SQL следующим образом:
'DELETE FROM students'
Тем не менее, это удалит все строки в таблице студентов. Обычно запрос DELETE связан с логическим выражением, указанным в предложении WHERE. Следующий оператор показывает, где параметр —
stmt = students.delete().where(students.c.id > 2)
Результирующее выражение SQL будет иметь связанный параметр, который будет подставляться во время выполнения при выполнении инструкции.
'DELETE FROM students WHERE students.id > :id_1'
Следующий пример кода удалит эти строки из таблицы учеников, имеющие фамилию как ‘Ханна’ —
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()
Чтобы проверить результат, обновите представление данных таблицы студентов в SQLiteStudio.