Rumah >pangkalan data >tutorial mysql >Bagaimana Menggunakan Pernyataan Disediakan PHP PDO dengan MySQL LIKE Queries?
PHP PDO Disediakan Kenyataan dengan MySQL LIKE Query
Apabila menanyakan data menggunakan PDO dalam PHP dengan keadaan LIKE, adalah penting untuk memahami yang betul pengendalian istilah carian. Berikut ialah penyelesaian untuk isu yang dilaporkan:
Kod awal tersilap menambahkan petikan berganda pada istilah carian semasa menyediakan pernyataan:
$ret = $prep->execute(array(':searchTerm' => '"%'.$searchTerm.'%"'));
Petikan tambahan ini tidak diperlukan. Penyata yang disediakan mengasingkan data daripada pertanyaan, jadi petikan tidak boleh dibenamkan.
Selain itu, kod digunakan secara salah WHERE hs.hs_text SEPERTI ":searchTerm" tanpa menambah simbol peratusan di sekeliling istilah carian.
Untuk membetulkan isu, kod yang diperbetulkan hendaklah melaksanakan pernyataan sebagai berikut:
$prep = $dbh->prepare($sql); $ret = $prep->execute(array(':searchTerm' => '%'.$searchTerm.'%'));
Penjelasan:
Pernyataan yang disediakan mengangkut data secara berasingan daripada pertanyaan, jadi nilai tidak digantikan secara langsung ke dalam rentetan pertanyaan. Petikan hanya diperlukan apabila membenamkan nilai dalam pertanyaan, yang tidak berlaku di sini.
Dengan menggunakan sintaks yang betul, pernyataan yang disediakan PDO boleh mencari data dengan berkesan menggunakan syarat LIKE dengan istilah carian yang disediakan.
Atas ialah kandungan terperinci Bagaimana Menggunakan Pernyataan Disediakan PHP PDO dengan MySQL LIKE Queries?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!