Php 在bindParam中使用LIKE进行MySQL PDO查询

Php 在bindParam中使用LIKE进行MySQL PDO查询,php,mysql,database,pdo,Php,Mysql,Database,Pdo,我已经阅读了多个关于如何编写这些查询的示例,但在使用bindParam 这是匹配以a开头的用户名的正确方法吗 $term = "a"; $term = "'$term%'"; $sql = "SELECT username FROM `user` WHERE username LIKE :term LIMIT 10"; $core = Connect::getInstance(); $stmt = $core->dbh

我已经阅读了多个关于如何编写这些查询的示例,但在使用
bindParam

这是匹配以a开头的用户名的正确方法吗

$term = "a";
$term = "'$term%'";

$sql = "SELECT username 
        FROM `user` 
        WHERE username LIKE :term 
        LIMIT 10";      

$core = Connect::getInstance();

$stmt = $core->dbh->prepare($sql);
$stmt->bindParam(':term', $term, PDO::PARAM_STR);
$stmt->execute();
$data = $stmt->fetchAll();

不,您不需要内部单引号,所以只需
$term=“$term%”

您现在运行的语句将尝试匹配
'a%'
,而不是
a%


bindParam将确保在将所有字符串数据提供给SQL语句时自动正确引用。

您可以使用bindValue,假设您有一个$query=“search string”

同样地

$stmt->bindValue(':term', '%'.$query.'%');

下面是一个示例代码:
$stmt->bindValue(':term', '%'.$query.'%');
$stmt->bindValue(':term', '%'.$query);