我正在尝试将数据从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>
请出示我的错误。
答案 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扩展。