ユーザーがサブジェクト領域のドロップダウン リストから選択して一連のデータベースを返すことができる単純な php フォームがあります (例: http://library.wabash.edu/biology.php )。ご覧のとおり、選択が行われて [送信] がクリックされるまで、何も返されません。ページが読み込まれるときに一連のデータベースが既に読み込まれている可能性はありますか (生物学データベースは Biology Dept ページに読み込まれるなど)、その後、ユーザーが別の選択を行えるようにすることはできますか? 私の経験不足がここに現れているので、事前にお詫び申し上げます。
<form action="<?php echo htmlentities($_SERVER['PHP_SELF']); ?>" method="post">
<select name="choice" id="choice">
<option value="Biology">Biology</option>
<option value="Chemistry">Chemistry</option>
<option value="Computer Science">Computer Science</option>
<option value="Mathematics">Mathematics</option>
<option value="Medicine">Medicine</option>
<option value="Physics">Physics</option>
</select>
<input type="submit" name="submit" value="Go" style="margin-left: 10px">
<input type="submit" name="reset" value="Clear" style="margin-left: 10px">
<input type="hidden" name="submitted" value="true"/>
</form>
<?php
if(isset($_POST['submit'])) {
$choice=$_POST['choice'];
$localhost="localhost";
$username="xxxxxxx";
$password="xxxxxxx";
$database="xxxxxxx";
$linkid=mysql_connect($localhost,$username,$password);
@mysql_select_db($database) or die( "Unable to select database");
mysql_select_db("databases",$linkid);
$resultid=mysql_query("SELECT name, mobile, app, tutorial, help
FROM databaselist
WHERE dept
LIKE '%{$choice}%'
ORDER BY sortname ASC", $linkid);
echo"<table>";
while ($row = mysql_fetch_row($resultid))
{
echo"<tr>";
foreach ($row as $field)
{
echo"<td>$field</td>";
}
echo"</tr>";
}
echo"</table>";
mysql_close($linkid);
}
?>