Rumah >pangkalan data >tutorial mysql >Bagaimana Menggunakan Pernyataan Disediakan PHP PDO dengan MySQL LIKE Queries?

Bagaimana Menggunakan Pernyataan Disediakan PHP PDO dengan MySQL LIKE Queries?

Susan Sarandon
Susan Sarandonasal
2024-12-20 01:53:13228semak imbas

How to Correctly Use PHP PDO Prepared Statements with 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!

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