当客户端按下按钮时 php 中的计数器

counter in php when client press button

我在 php 中有这部分代码。当玩家在客户端按下按钮(使用 ajax)时,我希望我的数据库显示下一条记录。但我不会。

if(isset($_POST['req'])){

$counter++;

$sql = "SELECT question FROM mytable WHERE id = $counter";

$result = $conn->query($sql);

if ($result->num_rows > 0) {

while($row = $result->fetch_assoc()) {
    echo $row["id"]." ". $row["question"]. " " . "<br>";
}
} else {
 echo "0 results";
}

}

最简单的方法是在 Ajax 请求中发送当前 ID。增加它然后用它从你的数据库中提取下一个问题

我建议将您的计数器存储在会话中。然后每次玩家执行此操作时,您都可以像这样给他们下一行:-

session_start();


if(isset($_POST['req'])){

    if ( ! isset($_SESSION['counter']) ) {
        $_SESSION['counter'] = 1;
    } else {
        $_SESSION['counter'] = $_SESSION['counter'] + 1;
    }

    $sql = "SELECT question FROM mytable WHERE id = {$_SESSION['counter']}";
    $result = $conn->query($sql);

    if ( ! $result ) {
        // log error to error log
        error_log(print_r($conn->errorinfo(),true), 3, 'app_error.log');
        echo "Temporary database issues, please try again later";
        header('Location: error_page.php');
        exit;
    }

    if ($result->num_rows > 0) {
        $row = $result->fetch_assoc();
        echo $row["id"]." ". $row["question"]. " " . "<br>";
    } else {
        echo "0 results";
    }
}