Membetulkan Sintaks LIKE Apabila Menggunakan bindParam untuk Pertanyaan PDO MySQL
Dalam pertanyaan MySQL PDO, menggunakan LIKE dengan bindParam boleh menjadi rumit. Soalan ini menunjukkan isu biasa yang dihadapi apabila cuba memadankan nama pengguna yang bermula dengan rentetan tertentu.
Sintaks yang salah yang disediakan dalam soalan menggunakan petikan tunggal dalam sekitar pembolehubah $term:
$term = "'$term%'";
Untuk membetulkannya, cuma alih keluar petikan tunggal dalam:
$term = "$term%";
Apabila menggunakan bindParam, PDO secara automatik mengendalikan rentetan memetik. Menambah petikan yang tidak perlu dalam pembolehubah $term boleh mengakibatkan padanan LIKE yang salah.
Pernyataan yang diperbetulkan sepatutnya kelihatan seperti ini:
$sql = "SELECT username FROM `user` WHERE username LIKE :term LIMIT 10"; $core = Connect::getInstance(); $stmt = $core->dbh->prepare($sql); $stmt->bindParam(':term', $term, PDO::PARAM_STR); $stmt->execute(); $data = $stmt->fetchAll();
Ini akan memadankan nama pengguna dengan betul yang bermula dengan pembolehubah $term , contohnya "a".
Atas ialah kandungan terperinci Mengapa `bindParam` Gagal Apabila Menggunakan `LIKE` dalam Pertanyaan PDO MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!