Rumah > pembangunan bahagian belakang > Tutorial Python > Bagaimana untuk Membetulkan 'TypeError: Tidak Semua Argumen Ditukar' dalam Pertanyaan MySQL Berparameter?

Bagaimana untuk Membetulkan 'TypeError: Tidak Semua Argumen Ditukar' dalam Pertanyaan MySQL Berparameter?

Linda Hamilton
Lepaskan: 2024-12-10 14:04:10
asal
348 orang telah melayarinya

How to Fix

TypeError: Tidak Semua Argumen Ditukar Semasa Pemformatan Rentetan dalam Pertanyaan SQL Berparameter

Kod anda untuk pertanyaan SQL berparameter membuang ralat "TypeError: tidak semua argumen ditukar semasa pemformatan rentetan" kerana anda cuba menggantikan rentetan secara langsung ke dalam pertanyaan. Pendekatan ini tidak berfungsi kerana ia menjangkakan senarai argumen akan ditukar kepada pertanyaan.

Untuk membetulkan isu ini, bukannya menggunakan:

cur.execute( "SELECT * FROM records WHERE email LIKE '%s'", search )
Salin selepas log masuk

ubah suai kod anda kepada:

cur.execute( "SELECT * FROM records WHERE email LIKE %s", [search] )
Salin selepas log masuk

Mengikut dokumentasi MySQLdb, parameter kedua execute() mewakili senarai objek yang hendak ditukar, membenarkan bilangan objek yang sewenang-wenangnya dalam satu pertanyaan. Dalam kes anda, walaupun hanya mempunyai satu objek, ia masih perlu boleh diubah.

Atas ialah kandungan terperinci Bagaimana untuk Membetulkan 'TypeError: Tidak Semua Argumen Ditukar' dalam Pertanyaan MySQL Berparameter?. 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