MySQL 的下拉框中没有数据

Data not coming in dropdown box from MySQL

我正在尝试从 MySQL table 获取数据到 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> 

请指出我的错误。

您的第一个 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>

这应该没问题。

问题很简单,您的第一个 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> 

Obviously I should also point out the the MYSQL_* PHP extension is now deprecate and therefore should not be used. If you are writing new code please look at the MYSQLI_* extension or the PDO extention.