簡體   English   中英

如何停止在PHP查詢第二次相同的數據顯示?

[英]how to stop same data display second time in php query?

我嘗試開發考試管理系統。 我不希望同一問題或同一ID不顯示用戶第二次或其他任何時間的考試。 如何給出這種條件?

我的功能是:

public function qustionShow($question, $limit=4){
    $show = $this->conn->query("select * from question where cat_id ='$question' ORDER BY RAND() LIMIT $limit");
    while ($row=$show->fetch_array(MYSQLI_ASSOC)){
        $this->qus[]=$row;
    }
    return $this->qus;  
}

您需要跟蹤已經問過的問題。 您可以將問題ID保存到會話中,如果您不想再次為會話選擇問題。

您可以將一個數組初始化為會話$ _SESSION ['questions_asked'] = array(); 然后問了一個問題,你會

array_push([THE QUESTION ID], $_SESSION['questions_asked']);

當然,無論您問什么問題,都需要用sql id替換[THE QUESTION ID]

請記住,您需要修改查詢以解決會話中保存的所有內容。

如果您不希望再次顯示它們,則需要記錄用戶已經看到的問題,並可能需要將其永久存儲在數據庫中。

可能您可以有一個表來存儲每個用戶的表

user_question_asked

至少有這兩列

[USER_ID] [question_id]

因此,每次詢問問題時,您都要插入當前的用戶ID和問題ID

那么您的查詢可能是

SELECT * FROM question where cat_id ='$question' AND [QUESTION_ID] NOT IN 
(SELECT question_id from  user_question_asked where user_id [CURRENT USER's ID] 
) ORDER BY RAND() LIMIT $limit;`

希望能有所幫助,但我不確定您的表/列結構是什么,但這是解決該問題的一些建議。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM