php - 如何将在线考试系统的答案存储到数据库

标签 php mysql

我正在创建一个在线考试系统,从数据库中获取问题和答案,并在单选按钮中显示选项。但是,问题是,如果我单击“保存”,它只会保存一个答案,而不是所有问题的答案

获取问题的php代码

 $quer=" SELECT * FROM questionset ORDER BY RAND() ";
 $query=mysqli_query($sql,$quer);
while($row = mysqli_fetch_array($query))
  {
  $na= $row['qus'];
  $opa= $row['opa'];
   $opb= $row['opb'];
  $opc= $row['opc'];
    $opd= $row['opd'];

 echo "<div class='pr3'>";

echo "<div id='question'>";
echo $na;
echo "</div>";
echo "<br/>";
echo "<form name='cart' method='post'>";
echo "<input type='radio' name='ans' value='" . $opa. "' onclick='answ(this.value)' >";
echo $opa;
echo "<br/>";
echo "<input type='radio' name='ans' value='" . $opb. "' onclick='answ(this.value)'>";
echo $opb;
echo "<br/>";
    echo "<input type='radio' name='ans' value='" . $opc. "' onclick='answ(this.value)'>";
echo $opc;
echo "<br/>";
echo "<input type='radio' name='ans' value='" . $opd. "' onclick='answ(this.value)'>";
echo $opd;
echo "<br/>";
echo "<input type='text' id='ansval' name='ansval' >";
    echo "</form>";

 echo " </div>";

  }

仅更新一个文本框的 JavaScript

<script>
function answ(answer) {
document.getElementById("ansval").value = answer;
}
</script>

最佳答案

所有问题的单选按钮名称均相同。您必须为每个答案集动态指定单选按钮名称。您可以使用以下代码:

$quer=" SELECT * FROM questionset ORDER BY RAND() ";
 $query=mysqli_query($sql,$quer);
while($row = mysqli_fetch_array($query))
  {
  $questionId = $row['questionId']; //primary key of question table
  $na= $row['qus'];
  $opa= $row['opa'];
   $opb= $row['opb'];
  $opc= $row['opc'];
    $opd= $row['opd'];

 echo "<div class='pr3'>";

echo "<div id='question'>";
echo $na;
echo "</div>";
echo "<br/>";
echo "<form name='cart' method='post'>";
echo "<input type='radio' name='ans<?php echo $questionId; ?>' value='" . $opa. "' onclick='answ(this.value,'<?php echo $questionId; ?>')' >";
echo $opa;
echo "<br/>";
echo "<input type='radio' name='ans<?php echo $questionId; ?>' value='" . $opb. "' onclick='answ(this.value,'<?php echo $questionId; ?>')'>";
echo $opb;
echo "<br/>";
    echo "<input type='radio' name='ans<?php echo $questionId; ?>' value='" . $opc. "' onclick='answ(this.value,'<?php echo $questionId; ?>')'>";
echo $opc;
echo "<br/>";
echo "<input type='radio' name='ans<?php echo $questionId; ?>' value='" . $opd. "' onclick='answ(this.value,'<?php echo $questionId; ?>')'>";
echo $opd;
echo "<br/>";
echo "<input type='text' id='ansval<?php echo $questionId; ?>' name='ansval<?php echo $questionId; ?>' >";
    echo "</form>";

 echo " </div>";

  } 

你的 javascript 函数将如下所示:

<script>
function answ(answer,qId) {
document.getElementById("ansval"+qId).value = answer;
}
</script>

答案提交后,您可以通过同样的方式获取提交的值。即 $_POST['ansval'.$questionId];在获取值之前,您必须创建另一个循环来获取所有问题 ID。

关于php - 如何将在线考试系统的答案存储到数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24464619/

相关文章:

php - 从文本中删除完整的 URL

mysql - VB.NET:使用变量生成 MySQL 查询

mysql - 包含连接的触发器

php - 数据库结构,怎么想

mysql - 强大的容错 MySQL 复制

javascript - 禁用当前页面的 JavaScript

php - 为 2 个空格而不是 4 个空格配置 PHP-cs-fixer 缩进?

php - 如何获得父子类别的项目计数?

mysql - 根据字段中的值删除重复行

javascript - 登录前需要注销