Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/69.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php pdo使用通配符准备语句_Php_Mysql_Pdo_Prepared Statement - Fatal编程技术网

Php pdo使用通配符准备语句

Php pdo使用通配符准备语句,php,mysql,pdo,prepared-statement,Php,Mysql,Pdo,Prepared Statement,我想执行以下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->p

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

它也可以通过以下方式使用bind param:

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

这可能是另一种选择:

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

对于您的第一次尝试-将
bindParam
更改为
bindValue
,然后打开,您也可以使用“不确定为什么会被否决”按钮,但请注意此解决方案也有效。:)我猜它被否决了,因为如果你的
$name
本身包含一个通配符,它不会被转义。我在DSN中没有charset=utf8,我用泰语字符搜索,这浪费了我的时间。