UPDATE式の使用
ザ・ update() ターゲットテーブルオブジェクトのメソッドは、同等のUPDATESQL式を作成します。
table.update().where(conditions).values(SET expressions)
ザ・ values()結果の更新オブジェクトのメソッドは、UPDATEのSET条件を指定するために使用されます。Noneのままにした場合、SET条件は、ステートメントの実行および/またはコンパイル中にステートメントに渡されたパラメーターから決定されます。
where句は、UPDATEステートメントのWHERE条件を説明するオプションの式です。
次のコードスニペットは、studentsテーブルの「lastname」列の値を「Khanna」から「Kapoor」に変更します-
stmt = students.update().where(students.c.lastname == 'Khanna').values(lastname = 'Kapoor')
stmtオブジェクトは、-に変換される更新オブジェクトです。
'UPDATE students SET lastname = :lastname WHERE students.lastname = :lastname_1'
バインドされたパラメータ lastname_1 次の場合に置き換えられます execute()メソッドが呼び出されます。完全な更新コードを以下に示します-
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.update().where(students.c.lastname=='Khanna').values(lastname='Kapoor')
conn.execute(stmt)
s = students.select()
conn.execute(s).fetchall()
上記のコードは次の出力を表示し、2行目は与えられたスクリーンショットのように更新操作の効果を示しています-
[
(1, 'Ravi', 'Kapoor'),
(2, 'Rajiv', 'Kapoor'),
(3, 'Komal', 'Bhandari'),
(4, 'Abdul', 'Sattar'),
(5, 'Priya', 'Rajhans')
]
同様の機能は、を使用しても実現できることに注意してください update() 以下に示すように、sqlalchemy.sql.expressionモジュールの関数-
from sqlalchemy.sql.expression import update
stmt = update(students).where(students.c.lastname == 'Khanna').values(lastname = 'Kapoor')