欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP實(shí)現(xiàn)類似題庫(kù)抽題效果

 更新時(shí)間:2018年08月16日 14:45:12   作者:顧北清  
這篇文章主要介紹了PHP實(shí)現(xiàn)類似題庫(kù)抽題效果,通過一個(gè)簡(jiǎn)單的小例子給大家介紹的非常詳細(xì),需要的朋友參考下吧

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

希望各位大佬輕噴。

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



?。繛槭裁匆糜⑽??,因?yàn)槲?,,沒搞定編碼問題😭。

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



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

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

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

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


input.html頁(yè)面:

<html>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  <form action="select.php" method="get">
    請(qǐng)輸入要隨機(jī)生成的題數(shù):<input type="text" name="input" />
    <input type="submit" name="Submit" value="提交" />
  </form>
</html>

error.html頁(yè)面:

<html>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  <p>您的輸入有誤,請(qǐng)重新輸入!</p>
</html>

select.php頁(yè)面:

<?php
  header("Content-type:text/html;charset=utf8");
  $connect=new mysqli('localhost','wy','000000','test');
  if(!$connect){
    die("數(shù)據(jù)庫(kù)連接失?。?);
  }              //連接數(shù)據(jù)庫(kù)
  $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)一個(gè)數(shù)組array
  $input=$_GET['input'];  //接受用戶的輸入
  if(empty($input) || $input>count($array)){ //判斷用戶的輸入是否為空或輸入大于題庫(kù)數(shù)量
    header("Location:error.html");  //輸入有誤重定向到錯(cuò)誤提示頁(yè)面
  }else{
    shuffle($array);  //將存放題目id的數(shù)組進(jìn)行隨機(jī)排序
    $k=0;        //用于取出rand數(shù)組中question時(shí)的id
    for($j=0;$j<$input;$j++){
      $rand=array_slice($array,0,$input);   //從數(shù)組的第一個(gè)數(shù)開始,取出用戶輸入數(shù)量個(gè)id存放進(jìn)一個(gè)數(shù)組
      $sql2="select * from test where id='{$rand[$k]}'"; //查找rand數(shù)組中每一個(gè)id對(duì)應(yīng)的question
      $result2=$connect->query($sql2);  //存放mysql語句返回的結(jié)果集
      while($row2=$result2->fetch_assoc()){
        echo $row2['question'];   //返回question對(duì)應(yīng)的內(nèi)容
        echo '<br />';
      }
      $k++;
    }
    $result2->free();  //釋放內(nèi)存
  }
  $result->free();    //釋放內(nèi)存
  $connect->close();   //關(guān)閉連接
?>

總結(jié)

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

相關(guān)文章

最新評(píng)論