> 백엔드 개발 > PHP 튜토리얼 > PDO에서 자리 표시자를 사용하여 LIKE 쿼리를 구현하는 방법은 무엇입니까?

PDO에서 자리 표시자를 사용하여 LIKE 쿼리를 구현하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-12 01:34:03
원래의
437명이 탐색했습니다.

How to Implement LIKE Queries with Placeholders in PDO?

PDO에서 LIKE 쿼리 구현

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%");
로그인 후 복사

바인드 변수에서 변수 값을 백분율 기호로 묶어 생성된 쿼리는 LIKE 절이 검색하도록 보장합니다. 지정된 단어가 포함된 주소입니다. 이렇게 조정하지 않으면 쿼리는 다음과 같이 생성됩니다.

SELECT * FROM tbl WHERE address LIKE '%"foo"%' OR address LIKE '%"bar"%'
로그인 후 복사

백분율 기호가 따옴표 안에 포함되어 검색 시 정확한 텍스트 "foo" 또는 "가 포함된 주소를 찾게 되므로 이 쿼리는 실패합니다. bar", 해당 용어가 포함된 단어가 아닙니다.

위 내용은 PDO에서 자리 표시자를 사용하여 LIKE 쿼리를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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