mysql PDO where like或query只返回1个结果

时间:2013-03-02 16:10:01

标签: mysql pdo sql-like

当我通过phpMyAdmin手动运行以下SQL时返回超过1行:

SELECT * 
FROM bread
WHERE (type LIKE '%hite%' OR type LIKE '%grain%' OR type LIKE '%brown%' ) 
AND bread_hide = 0 
LIMIT 20;

但是,当我在PDO中运行它时,它只返回一个结果。 SQL是针对每个搜索词动态构建的,如下所示:

 SELECT * FROM bread WHERE ( type LIKE :q0 OR type LIKE :q1 OR type LIKE :q2 ) AND bread_hide = 0 LIMIT 20; 

因此,如果用户输入“hite grain brown”,则绑定以下参数:

:q0 = %hite%
:q1 = %grain%
:q2 = %brown%

手动运行时,我得到以下结果:

white bread
wholegrain
brown bread

当我的PHP PDO查询运行时,我只得到最后一个:

brown bread

如果用户输入“hite grain”,则生病wholegrain而不是white bread

我希望有人知道原因/解决方法是什么,谢谢!

php代码: 以下是我将如何绑定参数,执行查询以及检索数据:

$statement_handle = $db_handle->prepare($breadSQL);
foreach($searchWord as $i=>$q) {
    $q = "%".$q."%";
    $statement_handle->bindParam(":q$i", $q);
}
$statement_handle->execute(); 
$statement_handle->setFetchMode(PDO::FETCH_ASSOC);
while($row = $statement_handle->fetch())
{
    $breadList[] = array('breadName' => $row['bread_name']);
}

固定代码:

foreach($searchWord as $i=>$q) {
    $q = "%".$q."%";
    $statement_handle->bindValue(":q$i", $q, PDO::PARAM_STR);
}

1 个答案:

答案 0 :(得分:0)

尝试使用带引号

的参数
:q0 = '%hite%'
:q1 = '%grain%'
:q2 = '%brown%'