我正在为搜索引擎编写脚本,其中所有字段都需要能够自己提交信息,或者与其他字段一起提交。字段是名称,城市,州,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查询本身的一个问题。
答案 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";
}