为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用LIKE语句创建PDO参数化查询?

如何使用LIKE语句创建PDO参数化查询?

PHP
POPMUISE 2019-07-02 11:01:58
如何使用LIKE语句创建PDO参数化查询?我的尝试是:$query = $database->prepare('SELECT * FROM table WHERE column LIKE "?%"');$query->execute(array('value'));while ($results = $query->fetch()) {    echo $results['column'];}
查看完整描述

3 回答

?
慕神8447489

TA贡献1780条经验 获得超1个赞

我刚发完邮件就想出来了:

$query = $database->prepare('SELECT * FROM table WHERE column LIKE ?');$query->execute(array('value%'));while ($results = $query->fetch()){
    echo $results['column'];}


查看完整回答
反对 回复 2019-07-02
?
大话西游666

TA贡献1817条经验 获得超14个赞

要使用LIKE和%部分匹配,您还可以这样做:column like concat('%', :dangerousstring, '%')使用命名参数:dangerousstring..换句话说,在您自己的查询中显式使用未转义%符号,这些符号是分开的,绝对不是用户输入。

编辑:我发现的另一种级联语法是使用串联运算符:\,所以它将变成简单的:where column like '%' || :dangerousstring || '%' etc

@Bobince提到这里这一点:

这个难度当您想要允许一个文字%_搜索字符串中的字符,而不让它充当通配符。

所以,这是其他的东西,当结合相似和参数化时要注意。


查看完整回答
反对 回复 2019-07-02
?
吃鸡游戏

TA贡献1829条经验 获得超7个赞


$query = $database->prepare('SELECT * FROM table WHERE column LIKE ?');

$query->bindValue(1, "%$value%", PDO::PARAM_STR);

$query->execute();


if (!$query->rowCount() == 0) 

{

    while ($results = $query->fetch()) 

    {

        echo $results['column'] . "<br />\n";

    }       

else 

{

    echo 'Nothing found';

}


查看完整回答
反对 回复 2019-07-02
  • 3 回答
  • 0 关注
  • 617 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信