使用PHP怎么實現(xiàn)題庫抽題效果?針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
10年積累的網(wǎng)站建設(shè)、網(wǎng)站制作經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有涿鹿免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。?。繛槭裁匆糜⑽??,因為我,,沒搞定編碼問題?。
接著我來進行抽題:
這樣就隨機抽出了三道題目。
現(xiàn)在來說說我的思路,希望各位大佬不吝賜教。
首先要實現(xiàn)這個功能,首先我需要三個頁面,一個是用戶輸入頁面input.html
,一個是后臺處理頁面select.php
,還有一個是錯誤警告頁面error.html
(如果用戶輸入為空,或者輸入的抽題數(shù)量超過了題庫的數(shù)量那么就報錯),然后是數(shù)據(jù)庫,數(shù)據(jù)庫分為兩列,一列是question
,用來存放題目,另一列是id
,用于標(biāo)識question
。
然后對用戶的輸入進行判斷:
input.html頁面:
error.html頁面:
您的輸入有誤,請重新輸入!
select.php頁面:
query($sql); $array=array(); $i=0; while($row=$result->fetch_row()){ foreach($row as $val){ $array[$i]=$val; $i ++; } } //將題目id存放進一個數(shù)組array $input=$_GET['input']; //接受用戶的輸入 if(empty($input) || $input>count($array)){ //判斷用戶的輸入是否為空或輸入大于題庫數(shù)量 header("Location:error.html"); //輸入有誤重定向到錯誤提示頁面 }else{ shuffle($array); //將存放題目id的數(shù)組進行隨機排序 $k=0; //用于取出rand數(shù)組中question時的id for($j=0;$j<$input;$j++){ $rand=array_slice($array,0,$input); //從數(shù)組的第一個數(shù)開始,取出用戶輸入數(shù)量個id存放進一個數(shù)組 $sql2="select * from test where id='{$rand[$k]}'"; //查找rand數(shù)組中每一個id對應(yīng)的question $result2=$connect->query($sql2); //存放mysql語句返回的結(jié)果集 while($row2=$result2->fetch_assoc()){ echo $row2['question']; //返回question對應(yīng)的內(nèi)容 echo '
'; } $k++; } $result2->free(); //釋放內(nèi)存 } $result->free(); //釋放內(nèi)存 $connect->close(); //關(guān)閉連接 ?>
關(guān)于使用PHP怎么實現(xiàn)題庫抽題效果問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。