php - 如何在php中将数据库记录一条一条发送到另一个页面

标签 php mysql database session

我正在创建一个类似于 http://www.sqlquiz.com/ 的测验系统我的结果页面有问题。 我已经创建了 4 个页面

index.php ---->welcomePage 我在查询字符串中使用变量 n

index.php

<p><a href="quizmain.php?n=1">Start SQL Quiz</a></p>

2.quizmain.php------------>此页面显示问题及其选项以及之后的内容 获取每个问题的响应后,它将转到 process.php 页面,在该页面中计算分数,并且每次计数器都会增加 1,以便在达到第 10 个问题后将显示最终结果页面

quizmain.php

 <?php 
    session_start();
    require_once("connection.php");
    extract($_REQUEST);

    $number = (int) $_GET['n']; //starting value 1
    echo $number;
    $n1=rand(1,100);

    $_SESSION['RQuestionNumber']=$n1;

    $q=mysql_query("select * from quiz WHERE qno = '".$n1."'");

    $a=mysql_fetch_array($q);


    echo $a['qno'];
    echo $a['ans'];

    ?>




<body>
    <table>
    <tr>
      <td width="757" height="390"><div align="center">


            <form method="post" action="process1.php">

               &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="a" />
              <?php echo $a[2]?></label>
          </p>
        <p><br />
              <label> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="b" />
                <?php echo $a[3]?></label>
          </p>
        <p><br />
              <label> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="c" />
                <?php echo $a[4]?></label>
          </p>
        <p><br />
              <label> </label>
              <label> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="d" />
                <?php echo $a[5]?></label>
          </p>

        <p>&nbsp; </p>
        <p>
            <label>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
          <input type="submit" value="Submit" name="Submit" />
          <input type="hidden" name="number" value="<?php echo $number; ?>" />
          </form>
            </label>
            <br />
            <br />
            <br />
        </p></td>
    </tr>
  </table>
</body>
</html>

process.php

 <?php 
    session_start(); 
    require_once('connection.php');
    extract($_REQUEST);
        //Check to see if score is set_error_handler
        if(!isset($_SESSION['score'])){
            $_SESSION['score'] = 0;
        }

        if($_POST)
        {
            $number = $_REQUEST['number'];  //value of number is 1 initially 
            $selected_choice = $_REQUEST['question'];
            $next = $number+1; //

        $total=10;  
        $_SESSION['RQuestionNumber'];


        $q = mysql_query("SELECT ans FROM quiz WHERE qno = '".$_SESSION['RQuestionNumber']."'");
        $result=mysql_fetch_array($q);

        //$store=array();



            //Compare
            if($result[0][0] == $selected_choice){
                //Answer is correct
                $_SESSION['score']++;
            }


            //Check if last question
            if($number == $total){
                header("location: resultTable.php");
                exit();
            } else {
                header("location: quizmain.php?n=".$next); //now the value of n is 2 
            }
        }
        ?>

结果表.php

现在在此页面中,我想打印测验期间出现的所有问题(同一组问题)以及标记的答案和正确的答案 我尝试过使用 session 变量,但它不起作用。

<?php session_start(); ?>
            <p>Final Score: <?php echo $_SESSION['score']; ?></p>

<?php session_destroy(); ?>

最佳答案

您的 session 值每次都会被覆盖,因此最后您将获得最后一个问题 ID。如果您想要所有问题 ID,请使用数组。试试这个:

quizmain.php

<?php 
    session_start();
    require_once("connection.php");
    extract($_REQUEST);

    $number = (int) $_GET['n']; //starting value 1
    echo $number;
    $n1=rand(1,100);

    $_SESSION['RQuestionNumber'][]=$n1;

    $q=mysql_query("select * from quiz WHERE qno = '".$n1."'");

    $a=mysql_fetch_array($q);


    echo $a['qno'];
    echo $a['ans'];

    ?>




<body>
    <table>
    <tr>
      <td width="757" height="390"><div align="center">


            <form method="post" action="process1.php">

               &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="a" />
              <?php echo $a[2]?></label>
          </p>
        <p><br />
              <label> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="b" />
                <?php echo $a[3]?></label>
          </p>
        <p><br />
              <label> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="c" />
                <?php echo $a[4]?></label>
          </p>
        <p><br />
              <label> </label>
              <label> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
              <input type="radio" name="question" value="d" />
                <?php echo $a[5]?></label>
          </p>

        <p>&nbsp; </p>
        <p>
            <label>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
          <input type="submit" value="Submit" name="Submit" />
          <input type="hidden" name="number" value="<?php echo $number; ?>" />
          </form>
            </label>
            <br />
            <br />
            <br />
        </p></td>
    </tr>
  </table>
</body>
</html>

process.php

<?php 
    session_start(); 
    require_once('connection.php');
    extract($_REQUEST);
        //Check to see if score is set_error_handler
        if(!isset($_SESSION['score'])){
            $_SESSION['score'] = 0;
        }

        if($_POST)
        {
            $number = $_REQUEST['number'];  //value of number is 1 initially 
            $selected_choice = $_REQUEST['question'];
            $next = $number+1; //

        $total=10;  
        $last_que = $_SESSION['RQuestionNumber'][count($_SESSION['RQuestionNumber'])-1];
       // $_SESSION['RQuestionNumber'];


        $q = mysql_query("SELECT ans FROM quiz WHERE qno = '".$last_que."'");
        $result=mysql_fetch_array($q);

        //$store=array();



            //Compare
            if($result[0][0] == $selected_choice){
                //Answer is correct
                $_SESSION['score']++;
            }


            //Check if last question
            if($number == $total){
                header("location: resultTable.php");
                exit();
            } else {
                header("location: quizmain.php?n=".$next); //now the value of n is 2 
            }
        }
        ?>

结果表.php

<?php session_start(); ?>
            <p>Final Score: <?php echo $_SESSION['score']; ?></p>
            <?php
            var_dump($_SESSION['RQuestionNumber']); //You will get all question number here
            ?>

<?php session_destroy(); ?>

关于php - 如何在php中将数据库记录一条一条发送到另一个页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45117643/

相关文章:

php - SQL 显示重复条目

php - 如何获取 MongoDB PHP 中的特定字段?

php - 将Mysql结果集转换为JSON会打印相同字段两次

mysql - 为什么我的 INNER JOIN 这么慢?服务器超时

mysql - 哪些数据库可以运行以下 SQL?

database - Hibernate 在架构更新时自动创建 SQL 迁移脚本以与 Flyway 一起使用

php - 更改 phpmyadmin 的默认时区

php - 根据产品属性添加自定义 woocommerce 电子邮件

php - 尝试显示类别

firebase - 允许用户只访问他们自己在 Firebase 数据库中的数据?