数据不在MySQL的下拉框中

时间:2015-05-30 19:07:07

标签: php mysql database-connection

我正在尝试将数据从MySQL表格下载到2个单独的下拉框中,但只有第一个下拉列表从数据库获取城市列表,为什么第二个下拉列表没有显示城市列表。这是PHP中的代码

<?php mysql_connect("localhost", "root", "") or die("Connection Failed");
mysql_select_db("flywest")or die("Connection Failed");
$query = "SELECT * FROM cities";
$result = mysql_query($query);
?>
Depart
<select name="formDepart" id="fromDepart">
  <?php while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) { ?> 
  <option value="<?php echo $line['city_name'];?>"> <?php echo $line['city_name'];?> 
  </option> 
  <?php } ?>
</select>
</p>
Arrive
<select name="formArrive" id="fromDepart">
  <?php while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) { ?> 
  <option value="<?php echo $line['city_name'];?>"> <?php echo $line['city_name'];?> 
  </option> 
  <?php } ?>
</select>  
<p> 

请出示我的错误。

2 个答案:

答案 0 :(得分:0)

你的第一个while循环已经到了结果集的末尾,因此再次运行while会从结束开始,无法继续进行。

您可以获取所有行并存储在变量中,然后使用该变量填充这两个下拉列表。

<?php     
$cities = array();
    while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {
    $cities[] = $line;
}
?>

<select name="formDepart" id="fromDepart">
  <?php foreach ($cities as $line) { ?> 
  <option value="<?php echo $line['city_name'];?>"> <?php echo $line['city_name'];?> 
  </option> 
  <?php } ?>
</select>
</p>
Arrive
<select name="formArrive" id="fromDepart">
  <?php foreach ($cities as $line) { ?> 
  <option value="<?php echo $line['city_name'];?>"> <?php echo $line['city_name'];?> 
  </option> 
  <?php } ?>
</select>

这应该可以正常工作。

答案 1 :(得分:0)

问题很简单,你的第一个while循环会消耗查询的所有结果,因此第二个while循环没有任何东西可以使用。

所以基本上第二个while循环没有剩余的数据要处理。

一种解决方案是在运行第二个while循环之前将结果集指针重置为结果集中的第一个条目。所以试试这个

<?php 
  mysql_connect("localhost", "root", "") or die("Connection Failed");
  mysql_select_db("flywest")or die("Connection Failed");

  $query = "SELECT * FROM cities";
  $result = mysql_query($query);
?>
Depart
<select name="formDepart" id="fromDepart">
<?php 
  while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) { 
?> 
    <option value="<?php echo $line['city_name'];?>"> <?php echo $line['city_name'];?> 
</option> 
<?php 
} 
?>
</select>
</p>
Arrive
<select name="formArrive" id="fromDepart">
<?php 

  // <-- new line to reset the resultset pointer
  mysql_data_seek($result,0);
  // >-- new line


  while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) { ?> 
    <option value="<?php echo $line['city_name'];?>"> <?php echo $line['city_name'];?> 
    </option> 
<?php 
} 
?>
</select>  
<p> 
  

显然我还应该指出MYSQL_ * PHP扩展现在弃用,因此不应该使用。如果您正在编写新代码,请查看MYSQLI_ *扩展或PDO扩展。