[英]PHP- how to insert form data first time and second time update same data
[英]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.