Подтвердить что ты не робот

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();
4b9b3361

Ответ 1

Он может работать с параметром bind также следующим образом:

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

Ответ 2

Это может быть альтернатива:

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