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!