>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 PDO 준비 문에 와일드카드를 올바르게 사용하는 방법은 무엇입니까?

MySQL에서 PDO 준비 문에 와일드카드를 올바르게 사용하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-28 21:32:15312검색

How to Properly Use Wildcards with PDO Prepared Statements in MySQL?

PDO 준비 문에서 와일드카드 사용

임의의 문자 수와 일치시키기 위해 %와 같은 와일드카드를 사용하는 MySQL 쿼리를 실행하는 것은 문제가 될 수 있습니다. PDO 준비문을 사용할 때. 이 글에서는 준비된 문에서 와일드카드를 효과적으로 활용하는 방법에 대해 설명합니다.

원래 쿼리

초기 목표는 다음 쿼리를 실행하는 것이었습니다.

SELECT * FROM `gc_users` WHERE `name` LIKE '%anyname%'

실패 시도

Prepared 문을 사용하려는 시도가 두 번 실패했습니다.

$stmt = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` LIKE :name");
$stmt->bindParam(':name', "%" . $name . "%");
$stmt->execute();

$stmt = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` LIKE '%:name%'");
$stmt->bindParam(':name', $name);
$stmt->execute();

해결책

문제는 바인딩 매개변수 사용에 있습니다. (). 준비된 명령문에서 와일드카드를 올바르게 사용하려면 binValue()를 사용해야 합니다. 아래 코드는 올바른 접근 방식을 보여줍니다.

$stmt = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` LIKE :name");
$stmt->bindValue(':name', '%' . $name . '%');
$stmt->execute();

대안

또 다른 실행 가능한 옵션은 다음과 같은 방식으로 바인딩Param()을 사용하도록 코드를 수정하는 것입니다.

$name = "%$name%";
$stmt = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` LIKE :name");
$stmt->bindParam(':name', $name);
$stmt->execute();

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

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