佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > PHP實現(xiàn)類似題庫抽題效果

PHP實現(xiàn)類似題庫抽題效果

熱門標(biāo)簽:服務(wù)器配置 阿里云 團(tuán)購網(wǎng)站 Linux服務(wù)器 銀行業(yè)務(wù) 電子圍欄 科大訊飛語音識別系統(tǒng) Mysql連接數(shù)設(shè)置

大家好,我顧某人又回來了,最近學(xué)了一點PHP,然后就想寫個簡單小例子試試,于是就寫了一個類似于從題庫抽題的東西,大概就是先輸入需要抽題的數(shù)量,然后從數(shù)據(jù)庫中隨機(jī)抽取題目。

希望各位大佬輕噴。

假設(shè)我現(xiàn)在有這樣一個題庫:



???為什么要用英文?,因為我,,沒搞定編碼問題😭。

接著我來進(jìn)行抽題:



這樣就隨機(jī)抽出了三道題目。

現(xiàn)在來說說我的思路,希望各位大佬不吝賜教。

首先要實現(xiàn)這個功能,首先我需要三個頁面,一個是用戶輸入頁面input.html,一個是后臺處理頁面select.php,還有一個是錯誤警告頁面error.html(如果用戶輸入為空,或者輸入的抽題數(shù)量超過了題庫的數(shù)量那么就報錯),然后是數(shù)據(jù)庫,數(shù)據(jù)庫分為兩列,一列是question,用來存放題目,另一列是id,用于標(biāo)識question。

然后對用戶的輸入進(jìn)行判斷:


input.html頁面:

html>
  meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  form action="select.php" method="get">
    請輸入要隨機(jī)生成的題數(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存放進(jìn)一個數(shù)組array
  $input=$_GET['input'];  //接受用戶的輸入
  if(empty($input) || $input>count($array)){ //判斷用戶的輸入是否為空或輸入大于題庫數(shù)量
    header("Location:error.html");  //輸入有誤重定向到錯誤提示頁面
  }else{
    shuffle($array);  //將存放題目id的數(shù)組進(jìn)行隨機(jī)排序
    $k=0;        //用于取出rand數(shù)組中question時的id
    for($j=0;$j$input;$j++){
      $rand=array_slice($array,0,$input);   //從數(shù)組的第一個數(shù)開始,取出用戶輸入數(shù)量個id存放進(jìn)一個數(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 'br />';
      }
      $k++;
    }
    $result2->free();  //釋放內(nèi)存
  }
  $result->free();    //釋放內(nèi)存
  $connect->close();   //關(guān)閉連接
?>

總結(jié)

以上所述是小編給大家介紹的PHP實現(xiàn)類似題庫抽題效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • java+vue實現(xiàn)添加單選題、多選題到題庫功能
  • php+mysql開發(fā)的最簡單在線題庫(在線做題系統(tǒng))完整案例
  • JavaScript實現(xiàn)英語單詞題庫

標(biāo)簽:棗莊 衢州 廣元 蚌埠 江蘇 衡水 萍鄉(xiāng) 大理

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實現(xiàn)類似題庫抽題效果》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    云阳县| 肇源县| 泽库县| 长葛市| 平阴县| 泰兴市| 长宁区| 渭南市| 修武县| 新乐市| 壤塘县| 定远县| 交口县| 仁怀市| 盐城市| 中山市| 清原| 高尔夫| 醴陵市| 三亚市| 达日县| 武邑县| 东乡县| 射阳县| 兴城市| 黄大仙区| 独山县| 林周县| 扶沟县| 南通市| 黄陵县| 三亚市| 桐城市| 彰武县| 苍溪县| 崇明县| 桐梓县| 高台县| 成武县| 布尔津县| 齐齐哈尔市|