Pembolehubah Bind Tidak Padan dalam Penyata Disediakan MySQLi
Apabila cuba melaksanakan borang log masuk menggunakan pernyataan yang disediakan dalam PHP, sesetengah pembangun menghadapi masalah yang mengecewakan ralat: "mysqli_stmt::bind_result(): Bilangan pembolehubah ikatan tidak sepadan dengan bilangan medan dalam pernyataan yang disediakan."
Ralat ini timbul apabila pertanyaan SQL dan fungsi bind_result() mengandungi ketidakpadanan dalam bilangan medan yang dipilih dan diberikan kepada pembolehubah. Mari kita periksa cara menangani isu ini berdasarkan kod yang disediakan.
Dalam kod yang disediakan:
$stmt = $mysqli->prepare("SELECT username AND password FROM users WHERE username = ?"); $stmt->bind_param('s', $username); $stmt->execute(); $stmt->bind_result($password, $username);
Isunya terletak pada pertanyaan SQL. Kata kunci "DAN" digunakan bukannya koma apabila memilih berbilang medan. Sintaks yang betul untuk memilih berbilang medan ialah memisahkannya dengan koma:
$stmt = $mysqli->prepare("SELECT username, password FROM users WHERE username = ?");
Selain itu, fungsi bind_result() hendaklah sepadan dengan bilangan medan yang dipilih. Dalam kes ini, dua medan dipilih, jadi fungsi bind_result() harus mempunyai dua pembolehubah:
$stmt->bind_result($username, $password);
Dengan membetulkan sintaks pilih dan menjajarkan fungsi bind_result() dengan bilangan medan yang dipilih, isu ini pembolehubah ikatan yang tidak sepadan akan diselesaikan, membolehkan borang log masuk berfungsi dengan betul.
Atas ialah kandungan terperinci Mengapa Pernyataan Disediakan MySQLi Saya Melemparkan Ralat 'Bilangan pembolehubah ikatan tidak sepadan dengan bilangan medan'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!