การอัปเดตตามลำดับพารามิเตอร์
แบบสอบถาม UPDATE ของ SQL ดิบมีส่วนคำสั่ง SET แสดงผลโดยโครงสร้าง update () โดยใช้ลำดับคอลัมน์ที่กำหนดในออบเจ็กต์ Table ต้นทาง ดังนั้นคำสั่ง UPDATE เฉพาะกับคอลัมน์ใดคอลัมน์หนึ่งจะแสดงผลเหมือนกันทุกครั้ง เนื่องจากพารามิเตอร์เองถูกส่งไปยังเมธอด Update.values () เป็นคีย์พจนานุกรม Python จึงไม่มีคำสั่งคงที่อื่น ๆ
ในบางกรณีลำดับของพารามิเตอร์ที่แสดงในประโยค SET มีความสำคัญ ใน MySQL การให้การอัปเดตค่าคอลัมน์จะขึ้นอยู่กับค่าของคอลัมน์อื่น ๆ
ผลลัพธ์ของคำสั่งต่อไปนี้ -
UPDATE table1 SET x = y + 10, y = 20
จะมีผลลัพธ์ที่แตกต่างจาก -
UPDATE table1 SET y = 20, x = y + 10
ประโยค SET ใน MySQL ได้รับการประเมินตามมูลค่าและไม่ได้คำนวณตามแต่ละแถว เพื่อจุดประสงค์นี้ไฟล์preserve_parameter_orderถูกนำมาใช้. รายการ Python ของ 2-tuples ถูกกำหนดให้เป็นอาร์กิวเมนต์ของไฟล์Update.values() วิธีการ -
stmt = table1.update(preserve_parameter_order = True).\
values([(table1.c.y, 20), (table1.c.x, table1.c.y + 10)])
วัตถุรายการจะคล้ายกับพจนานุกรมยกเว้นว่าจะได้รับคำสั่ง เพื่อให้แน่ใจว่าส่วนคำสั่ง SET ของคอลัมน์“ y” จะแสดงผลก่อนจากนั้นจึงใช้คำสั่ง SET ของคอลัมน์“ x”