一尘不染

pdo使用通配符准备语句

mysql

我要执行以下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();

阅读 209

收藏
2020-05-17

共1个答案

一尘不染

它也可以通过以下方式与绑定参数一起使用:

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