PHP의 PDO 클래스(MySQL 드라이버)로 작업할 때 준비된 문을 사용하여 MySQL LIKE 쿼리를 실행할 수 있습니다. 당황스러운 일이 될 것입니다. 겉으로는 간단해 보이는 구문이 원하는 결과를 얻지 못하는 경우가 많습니다.
MySQL 클라이언트를 사용하여 데이터를 원활하게 검색하는 다음 쿼리를 고려해 보세요.
SELECT ... FROM hs ... WHERE hs.hs_text LIKE "%searchTerm%" LIMIT 25;
The Conundrum
그러나 이 쿼리를 PHP로 포팅하면 구문에 관계없이 어떤 결과도 반환할 수 없다는 좌절감을 느낄 수 있습니다. 시도. 아래 코드는 이 문제를 보여줍니다.
$sql = 'SELECT ... FROM hs ... WHERE hs.hs_text LIKE :searchTerm LIMIT 25'; $prep = $dbh->prepare($sql); $ret = $prep->execute(array(':searchTerm' => '"%'.$searchTerm.'%"'));
검색어를 CONCAT('%', ?, '%'), "%:searchTerm%" 또는 ":searchTerm"으로 제공하려고 시도하는 반면, 이에 따라 실행 라인을 수정하면 소용이 없습니다.
솔루션
이 난제를 해결하는 열쇠는 준비된 명령문이 데이터를 처리하는 방법을 이해하는 데 있습니다. 쿼리와 별도로 데이터를 전달하므로 값을 삽입할 때 따옴표가 필요하지 않습니다.
따라서 올바른 해결 방법은 다음과 같습니다.
$prep = $dbh->prepare($sql); $ret = $prep->execute(array(':searchTerm' => '%'.$searchTerm.'%'));
검색어 매개변수에서 묶은 큰따옴표를 제거합니다. , 이제 준비된 문의 기능을 활용하여 LIKE 쿼리를 성공적으로 실행할 수 있습니다.
위 내용은 내 PHP PDO 준비 문이 MySQL LIKE 쿼리와 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!