web-dev-qa-db-ja.com

ワイルドカードを使用した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();
30
K. D.

次のようにbind paramでも動作します。

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

これは代わりになるかもしれません:

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