> 데이터 베이스 > MySQL 튜토리얼 > 내 PHP PDO 준비 문이 MySQL LIKE 쿼리와 작동하지 않는 이유는 무엇입니까?

내 PHP PDO 준비 문이 MySQL LIKE 쿼리와 작동하지 않는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-30 10:41:13
원래의
509명이 탐색했습니다.

Why Doesn't My PHP PDO Prepared Statement Work with MySQL LIKE Queries?

PHP PDO 준비된 문 - MySQL LIKE 쿼리: 수수께끼

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿