1

我是 php 和 mysql 的新手,所以我的查询需要一些帮助。这是我的 sql 查询

SELECT * FROM table1 WHERE (Name LIKE '%$keyword%' OR ZipCode LIKE '%$keyword%') AND Category LIKE '$category' AND Country LIKE '$country' LIMIT $start, $limit

现在我想做的就是

  1. 此查询应使用带有 name 关键字的文本字段搜索带有 Name 或 ZipCode 的列名称。即关键字与 Name 列或 ZipCode 匹配。
  2. 如果没有输入关键字并且仅从下拉列表中选择了一个国家,该查询也应该有效。
  3. 如果没有输入关键字或国家,并且仅从下拉列表中选择了一个类别,该查询也应该有效。

用更简单的话来说,如果选择了事物关键字、国家或类别中的任何一个,则搜索应该相应地显示结果。此外,如果输入了所有字段,它也应该可以工作。我设法做到了一半,但有时它给了我错误的结果。请帮忙。

4

2 回答 2

9

您可以检查设置了哪些字段并在运行时进行相应的查询。你可以这样做:

$query = "";
$keyword = $_REQUEST['keyword'];
$country = $_REQUEST['country'];
$category = $_REQUEST['category'];
if(isset($keyword)){//if keyword set goes here
   $query = "SELECT * FROM table1 WHERE Name LIKE '%$keyword%' OR ZipCode LIKE '%$keyword%' OR country LIKE '%$keyword%'";
   if(isset($category)){
     $query .= "AND category LIKE '$category'";
   }
   if(isset($country)){
     $query . = "AND country LIKE '$country'"
   }
}else if (isset($category)){ //if keyword not set but category set then goes here
  $query = "SELECT * FROM table1 WHERE category LIKE '$category'";
  if(isset($country)){
    $query . = "AND country LIKE '$country'";
  }
}else if(isset($country)){//if only country set goes here
  $query = "SELECT * FROM table1 WHERE country LIKE '$country'"
}
于 2012-11-09T17:02:39.153 回答
1

我建议使用几个不同的查询(每个搜索参数组合一个),使用 php 来决定使用哪个或使用 php 动态构建一个。

请注意,使用以 % 开头的 like 可能会很慢。

如果您真的想将其作为一个声明(我不推荐),那么:-

SELECT * 
FROM table1 
WHERE (Name LIKE '%$keyword%' OR ZipCode LIKE '%$keyword%' OR '$keyword' = '') 
AND (Category = '$category' OR '$category' = '' )
AND (Country = '$country' OR '$country' = '' )
LIMIT $start, $limit

或者动态构建它

$ConditionArray = array();
if ($keyword != '') $ConditionArray[] = "(Name LIKE '%$keyword%' OR ZipCode LIKE '%$keyword%' OR '$keyword' = '')";
if ($category != '') $ConditionArray[] = "Category = '$category'";
if ($country != '') $ConditionArray[] = "Country = '$country'";

if (count($ConditionArray) > 0)
{
    $query = "
    SELECT *
    FROM table 1
    WHERE ".implode(' AND ', $ConditionArray);
}
于 2012-11-09T16:47:38.093 回答