>데이터 베이스 >MySQL 튜토리얼 >MySQL LIKE 쿼리와 함께 PHP PDO 준비 문을 올바르게 사용하는 방법은 무엇입니까?

MySQL LIKE 쿼리와 함께 PHP PDO 준비 문을 올바르게 사용하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-20 01:53:13226검색

How to Correctly Use PHP PDO Prepared Statements with MySQL LIKE Queries?

MySQL LIKE 쿼리가 포함된 PHP PDO 준비 문

LIKE 조건이 있는 PHP에서 PDO를 사용하여 데이터를 쿼리할 때 올바른 구문을 이해하는 것이 중요합니다. 검색어 처리. 보고된 문제에 대한 해결 방법은 다음과 같습니다.

문을 준비할 때 초기 코드에서 검색어에 큰따옴표를 잘못 추가했습니다.

$ret = $prep->execute(array(':searchTerm' => '"%'.$searchTerm.'%"'));

이 추가 인용은 필요하지 않습니다. 준비된 문은 쿼리에서 데이터를 분리하므로 따옴표를 삽입해서는 안 됩니다.

또한 코드는 검색어 주위에 백분율 기호를 추가하지 않고 WHERE hs.hs_text LIKE ":searchTerm"을 잘못 사용했습니다.

문제를 해결하려면 수정된 코드에서 다음과 같이 문을 실행해야 합니다. 다음:

$prep = $dbh->prepare($sql);
$ret = $prep->execute(array(':searchTerm' => '%'.$searchTerm.'%'));

설명:

준비된 문은 쿼리와 별도로 데이터를 전송하므로 값이 쿼리 문자열로 직접 대체되지 않습니다. 따옴표는 쿼리 내에 값을 포함할 때만 필요하지만 여기서는 그렇지 않습니다.

올바른 구문을 사용하면 PDO 준비된 문은 제공된 검색어와 함께 LIKE 조건을 사용하여 데이터를 효과적으로 검색할 수 있습니다.

위 내용은 MySQL LIKE 쿼리와 함께 PHP PDO 준비 문을 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.