PHP實現(xiàn)類似題庫抽題效果
大家好,我顧某人又回來了,最近學了一點PHP,然后就想寫個簡單小例子試試,于是就寫了一個類似于從題庫抽題的東西,大概就是先輸入需要抽題的數(shù)量,然后從數(shù)據(jù)庫中隨機抽取題目。
希望各位大佬輕噴。
假設我現(xiàn)在有這樣一個題庫:

???為什么要用英文?,因為我,,沒搞定編碼問題😭。
接著我來進行抽題:


這樣就隨機抽出了三道題目。
現(xiàn)在來說說我的思路,希望各位大佬不吝賜教。
首先要實現(xiàn)這個功能,首先我需要三個頁面,一個是用戶輸入頁面input.html,一個是后臺處理頁面select.php,還有一個是錯誤警告頁面error.html(如果用戶輸入為空,或者輸入的抽題數(shù)量超過了題庫的數(shù)量那么就報錯),然后是數(shù)據(jù)庫,數(shù)據(jù)庫分為兩列,一列是question,用來存放題目,另一列是id,用于標識question。
然后對用戶的輸入進行判斷:

input.html頁面:
<html>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<form action="select.php" method="get">
請輸入要隨機生成的題數(shù):<input type="text" name="input" />
<input type="submit" name="Submit" value="提交" />
</form>
</html>
error.html頁面:
<html> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <p>您的輸入有誤,請重新輸入!</p> </html>
select.php頁面:
<?php
header("Content-type:text/html;charset=utf8");
$connect=new mysqli('localhost','wy','000000','test');
if(!$connect){
die("數(shù)據(jù)庫連接失??!");
} //連接數(shù)據(jù)庫
$sql="select id from test";
$result=$connect->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對應的question
$result2=$connect->query($sql2); //存放mysql語句返回的結果集
while($row2=$result2->fetch_assoc()){
echo $row2['question']; //返回question對應的內(nèi)容
echo '<br />';
}
$k++;
}
$result2->free(); //釋放內(nèi)存
}
$result->free(); //釋放內(nèi)存
$connect->close(); //關閉連接
?>
總結
以上所述是小編給大家介紹的PHP實現(xiàn)類似題庫抽題效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
Laravel基礎_關于view共享數(shù)據(jù)的示例講解
今天小編就為大家分享一篇Laravel基礎_關于view共享數(shù)據(jù)的示例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
jQuery Mobile + PHP實現(xiàn)文件上傳
這篇文章主要介紹了jQuery Mobile + PHP實現(xiàn)文件上傳的方法實例,以及由于自己疏忽造成的問題的解決方法,這里推薦給大家,有需要的小伙伴參考下2014-12-12
PHP批量查詢WordPress留言者E-mail地址實現(xiàn)方法
這篇文章主要介紹了PHP批量查詢WordPress留言者E-mail地址實現(xiàn)方法,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2015-02-02

