33

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

2 に答える 2

1

これは代替案になる可能性があります:

$className = '%' . $this->className . '%';
$query->bind_param('s', $className);
于 2014-06-26T03:08:46.513 に答える