PDO에서 LIKE 쿼리 구현
PDO를 사용하여 LIKE 연산자가 포함된 쿼리를 실행할 때는 쿼리를 올바르게 구성하는 방법을 이해하는 것이 중요합니다. 쿼리와 매개변수. 다음 쿼리를 고려하십시오.
"$query = "SELECT * FROM tbl WHERE address LIKE '%?%' OR address LIKE '%?%'";
$params = array($var1, $ var2);"
오류:
백분율 기호(%)가 매개변수로 지정되지 않고 쿼리 자체에 포함되어 있기 때문에 쿼리 결과 레코드가 반환되지 않습니다.
해결책:
이 문제를 해결하려면:
$query = "SELECT * FROM tbl WHERE address LIKE ? OR address LIKE ?"; $params = array("%$var1%", "%$var2%"); $stmt = $handle->prepare($query); $stmt->execute($params);
설명:
포함 매개변수 내의 백분율 기호는 쿼리가 실행될 때 자리 표시자로 올바르게 처리되는지 확인합니다. 이는 PDO가 해당 값을 실제 검색어로 대체하도록 지시하여 LIKE 작업이 올바르게 수행되도록 합니다.
원본 코드에서 생성된 쿼리를 검사하면 "SELECT * 라인을 따라 뭔가를 발견할 수 있습니다. FROM tbl WHERE address LIKE '%"foo"%' OR address LIKE '%"bar"%'", 여기서 준비된 문은 이미 인용된 문자열 내의 값을 실수로 인용하고 있습니다. 위에 설명된 올바른 접근 방식을 따르면 이 문제를 해결하고 PDO에서 LIKE 쿼리를 성공적으로 실행할 수 있습니다.
위 내용은 PDO에서 매개변수를 사용하여 LIKE 쿼리를 올바르게 구성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!