0

3 つのフィールドを含む検索領域があります。1 つは入力フィールドで、他の 2 つはドロップダウン メニューです。誰かが入力フィールドに何かを入力するか、両方のドロップダウン (州と都市) から選択します。

入力検索は正常に機能します。選択メニューはありません。

これがフォームです。

<form name="ffl_finder" method="get" action="index.php">
  Enter a Zip Code to find a Firearms Dealer near you: &nbsp;<br />
  <input name="q" type="text" id="q" size="40">

  Select a State AND a City<br />
  <select name="qoption2">
    <option value="" selected="selected">Select . . .</option>

<?php
$sql2 = "SELECT DISTINCT state from ffl_list order by state asc";
$rs_results2 = mysql_query($sql2) or die(mysql_error());

while ($rrows2 = mysql_fetch_array($rs_results2)) {
?>

    <option value="<?php echo $rrows2[state]; ?>"><?php echo $rrows2[state]; ?></option>

<?php
    }
?>          
  </select>

  <select name="qoption3">
    <option value="" selected="selected">Select . . .</option>

<?php

$sql3 = "SELECT DISTINCT city from ffl_list order by city asc";
$rs_results3 = mysql_query($sql3) or die(mysql_error());

while ($rrows3 = mysql_fetch_array($rs_results3)) {
?>
    <option value="<?php echo $rrows3[city]; ?>"><?php echo $rrows3[city]; ?></option>

<?php
    }
?>          
  </select>
  <input name="doSearch" type="submit" id="doSearch" value="Search">                        
</form>

クエリは次のとおりです。

    <?php if ($get['doSearch'] == 'Search') {

    //$cond2 = '';
  if($get['qoption2'] != '') {
  $cond2 = "`state` = 'qoption2'";
  }
//$cond3 = '';
  if($get['qoption3'] != '') {
  $cond3 = "`city` = 'qoption3'";
  }                         

  if($get['q'] == '') { 
  $sql = "select * from ffl_list where $cond2 and $cond3 order by state asc, city asc"; 
  }
  else { 
  $sql = "select * from ffl_list where `zip` = '$_REQUEST[q]' ORDER BY `id` asc";     
  } 
      $rs_results = mysql_query($sql) or die(mysql_error());
    } ?>

都市と州の両方を検索するクエリが必要ですが、条件を正しく取得できないようです。私はこれがたくさんのコードであることを知っていますが、誰かがそれを助けることができれば素晴らしいでしょう.

ありがとう、

クリント

4

1 に答える 1