【发布时间】:2013-04-21 18:17:39
【问题描述】:
我想执行下面的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();
【问题讨论】:
-
第一次尝试 - 将
bindParam更改为bindValue并转为error reporting for PDO
标签: php mysql pdo prepared-statement