Rumah >pangkalan data >tutorial mysql >Mengapa `bindParam` Gagal Apabila Menggunakan `LIKE` dalam Pertanyaan PDO MySQL?

Mengapa `bindParam` Gagal Apabila Menggunakan `LIKE` dalam Pertanyaan PDO MySQL?

Susan Sarandon
Susan Sarandonasal
2024-11-13 10:36:02270semak imbas

Why Does `bindParam` Fail When Using `LIKE` in MySQL PDO Queries?

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!

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