PHP MySQL多个搜索查询使用选项/选择HTML表单标签

时间:2011-09-06 06:45:46

标签: php mysql html

我正在尝试使用两个搜索字段设置基本的MySQL LIKE搜索。我不想拥有它,所以它是多个可选的搜索字段,例如if(isset($_POST['city']) || isset($_POST['name']))我不确定如何使用HTML <select name=""><option value="">...查看,因为您无法为每个<select>字段定义名称。那么,首先......你如何进行MySQL <select>搜索,每个搜索产生它自己的结果?那么,我如何正确查询多个搜索选项?我正在使用“文本框”+ <select>搜索。

            <input type="text" name="type" />  
            <select name="location">
               <option value="Chicago">Chicago</option>
               <option value="New York">New York</option>
            </select>
            <input type="submit" value="Search" />

MySQL的:

              $query = "SELECT 
              name, type, description, location, zip_code, phone_number
              FROM search
              WHERE type LIKE '%$type%'
              OR location LIKE 'Chicago'
              OR location LIKE 'New York'
              ";

我知道我在OR条款上做错了。我不完全确定如何正确执行<option> / <select> HTML表单标记搜索查询。

2 个答案:

答案 0 :(得分:4)

HTML

<select multiple name="location[]" size="2">

PHP

$w     = array();
$where = '';
foreach ($_POST['location'] as $loc){
  $loc = mysql_real_escape_string($loc);
  $w[] = "location = '$loc'";
}
if (!empty($_POST['type'])){
  $w[] = "type LIKE '%".mysql_real_escape_string($_POST['type'])."%'";
}
if ($w) $where = implode(' OR ',$w);

答案 1 :(得分:0)

我不确定你想要什么,但试试这个:

PHP:

// mysql escape
$locations = array_map("mysql_real_escape_string", $_POST['location']);
// add locations to query string
$locations = implode("','",$location);

$query = "SELECT 
              name, type, description, location, zip_code, phone_number
              FROM search
              WHERE location IN ('$locations')
              ";
if (isset($_POST['type']) && !empty($_POST['type'])){
  $query .= " or type LIKE '%".mysql_real_escape_string($_POST['type'])."%'";
}