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
Linda Hamiltonasal
2024-12-10 14:04:10379semak imbas

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 )

ubah suai kod anda kepada:

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

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!

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