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
Lepaskan: 2024-11-08 17:01:02
asal
968 orang telah melayarinya

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)   
Salin selepas log masuk

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))
Salin selepas log masuk

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))
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan