Rumah >pangkalan data >tutorial mysql >Mengapa Pernyataan KEMASKINI MYSQL Python Saya dengan Pembolehubah Gagal?

Mengapa Pernyataan KEMASKINI MYSQL Python Saya dengan Pembolehubah Gagal?

Susan Sarandon
Susan Sarandonasal
2024-11-08 17:01:02975semak imbas

Why Is My Python MYSQL UPDATE Statement with Variables Failing?

Menyelesaikan masalah Python MYSQL UPDATE Statement with Variables

Apabila mencipta pernyataan MYSQL UPDATE dengan pembolehubah dalam Python, adalah penting untuk memastikan ketepatannya. Satu ralat biasa yang dihadapi adalah seperti berikut:

cursor.execute ("UPDATE tblTableName SET Year=%s" % Year ", Month=%s" % Month ", Day=%s" % Day ", Hour=%s" % Hour ", Minute=%s" Minute "WHERE Server=%s " % ServerID)   

Di Mana Anda Silap?

Isunya terletak pada cara pembolehubah dimasukkan ke dalam pernyataan. Daripada menggunakan kaedah yang betul, coretan ini hanya menggabungkan rentetan dengan pembolehubah, yang tidak disokong oleh MYSQL.

Pendekatan yang Betul

Untuk membetulkan ralat, anda perlu untuk menggunakan pertanyaan berparameter, di mana pembolehubah diwakili oleh ruang letak dan diluluskan sebagai hujah yang berasingan. Berikut ialah pendekatan yang betul:

cursor.execute ("""
   UPDATE tblTableName
   SET Year=%s, Month=%s, Day=%s, Hour=%s, Minute=%s
   WHERE Server=%s
""", (Year, Month, Day, Hour, Minute, ServerID))

Kaedah Alternatif

Sebagai alternatif, anda boleh menggunakan manipulasi rentetan asas, tetapi tidak digalakkan kerana kelemahan suntikan SQL:

cursor.execute ("UPDATE tblTableName SET Year=%s, Month=%s, Day=%s, Hour=%s, Minute=%s WHERE Server='%s' " % (Year, Month, Day, Hour, Minute, ServerID))

Tambahan Nota

Perlu diingat bahawa hujung belakang pangkalan data yang berbeza mungkin mempunyai konvensyen yang berbeza untuk penggantian rentetan. Contohnya, SQLite menggunakan petikan tunggal untuk nilai rentetan dalam pertanyaan kemas kini.

Atas ialah kandungan terperinci Mengapa Pernyataan KEMASKINI MYSQL Python Saya dengan Pembolehubah Gagal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn