无论输入如何,搜索引擎的查询都会返回相同的结果

时间:2016-02-07 20:19:52

标签: php mysql

我正在为搜索引擎编写脚本,其中所有字段都需要能够自己提交信息,或者与其他字段一起提交。字段是名称,城市,州,ZIP,国家,Category_1。代码如下:

"SELECT * FROM table WHERE Name LIKE '%$get_name%' 
OR City LIKE '%$get_city%' 
OR State LIKE '%$get_state%' 
OR ZIP LIKE '%$get_zip%' 
OR Country LIKE '%$get_country%' 
OR Category_1 LIKE '%$get_category1%' 
LIMIT 0, 10";

如果我从输入中回显所有变量,它们都是正确的。但是,无论用户输入是什么,查询都会显示相同的结果。有什么建议?这似乎是MYSQL查询本身的一个问题。

1 个答案:

答案 0 :(得分:1)

如果任何变量为空,您将获得所有结果。 它与Name LIKE '%%' =所有结果相同。

您可以使用它:

$fields = array(
    'Name'  => $get_name,
    'City'  => $get_city,
    'State' => $get_state,
    'ZIP'   => $get_zip,
    'Country'   => $get_country,
    'Category_1'    => $get_category1,
);

$query = "";
foreach($fields as $k => $data) {
    if(trim($data) != '') {
        $query .= ($query ? ' OR ' : 'WHERE ') . "$k LIKE '%% $data'";
    }
}

if($query) {
    $query = "SELECT * FROM table $query LIMIT 0, 10";
}