> 백엔드 개발 > PHP 튜토리얼 > PDO에서 LIKE 연산자를 특수 문자와 올바르게 바인딩하는 방법은 무엇입니까?

PDO에서 LIKE 연산자를 특수 문자와 올바르게 바인딩하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-28 19:23:15
원래의
522명이 탐색했습니다.

How to Properly Bind LIKE Operators with Special Characters in PDO?

PDO 바인딩과 함께 LIKE 연산자 사용

LIKE 값을 PDO와 바인딩하면 일치하는 패턴. 이 특정 쿼리에는:

SELECT wrd FROM tablename WHERE wrd LIKE '$partial%'
로그인 후 복사

부분 문자열 '$partial%'을 바인딩하는 데는 여러 가지 옵션이 있습니다.

  • 옵션 1:
SELECT wrd FROM tablename WHERE wrd LIKE ':partial%'
로그인 후 복사

여기서 ':partial' 매개변수는 '$partial="somet"', 문자열 끝에 와일드카드 '%'를 추가합니다.

  • 옵션 2:
SELECT wrd FROM tablename WHERE wrd LIKE ':partial'
로그인 후 복사

이 경우 ':partial' 매개변수는 '$partial="somet%"'에 바인딩되며, 이는 바인딩에 와일드카드 문자를 포함합니다. value.

  • 옵션 3(대체):
SELECT wrd FROM tablename WHERE wrd LIKE CONCAT(:partial, '%')
로그인 후 복사

이 옵션을 사용하면 MySQL 쿼리 내에서 문자열 연결을 수행할 수 있습니다. PHP 코드보다.

특수 처리 문자

부분 문자열에 '%', '_' 또는 ''와 같은 특수 문자가 포함된 경우 이를 올바르게 이스케이프하려면 더 복잡한 방법이 필요합니다. 예는 다음과 같습니다.

$stmt = $db->prepare("SELECT wrd FROM tablename WHERE wrd LIKE :term ESCAPE '+'");
$escaped = str_replace(array('+', '%', '_'), array('++', '+%', '+_'), $var);
$stmt->bindParam(':term', $escaped);
로그인 후 복사

이 코드에서 특수 문자는 MySQL에서 올바르게 해석되도록 이스케이프 시퀀스(' ', ' %' 및 ' _')로 대체됩니다.

위 내용은 PDO에서 LIKE 연산자를 특수 문자와 올바르게 바인딩하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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