programing

pdo가 와일드카드로 준비한 문

kingscode 2023. 9. 18. 23:03
반응형

pdo가 와일드카드로 준비한 문

다음과 같은 mysql 쿼리를 실행하고자 합니다.

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

나는 이것을 시도했지만 성공하지 못했습니다.

$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();

그래서 준비된 문장과 함께 % 와일드카드 사용이 가능한지 문의드립니다.

/편집

감사해요.와 통합니다.bindValue:

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

bind param에서도 다음과 같은 방식으로 작동할 수 있습니다.

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

이것이 대안이 될 수 있습니다.

$className = '%' . $this->className . '%';
$query->bind_param('s', $className);

언급URL : https://stackoverflow.com/questions/16255657/pdo-prepared-statements-with-wildcards

반응형