使用 PHP 開發知識問答網站中的問題評分和排序功能
隨著網路的發展,知識問答網站如今已成為人們獲取知識和解決問題的重要管道之一。這些網站給予使用者提問、回答和評論的自由,可是如何對問題進行評分和排序成為了一個關鍵的問題。本文將介紹如何使用PHP開發知識問答網站中的問題評分和排序功能。
首先,我們需要在資料庫中建立相關的表格來儲存問題和評分資料。假設我們有兩個表格,一個是問題表格questions,包含問題的ID、標題和內容等字段,另一個是評分錶格ratings,包含評分的ID、問題ID、用戶ID和評分值等字段。
CREATE TABLE questions ( id INT AUTO_INCREMENT PRIMARY KEY, title VARCHAR(255), content TEXT ); CREATE TABLE ratings ( id INT AUTO_INCREMENT PRIMARY KEY, question_id INT, user_id INT, rating INT );
在知識問答網站中,使用者可以對問題進行評分,以表達對問題的滿意程度。我們可以在問題詳情頁的下方新增一個評分元件,使用者可以透過點擊按鈕來對問題進行評分。
<?php // 获取当前问题的ID $questionId = $_GET['id']; if ($_SERVER['REQUEST_METHOD'] === 'POST') { // 获取用户ID和评分值 $userId = $_SESSION['user_id']; $rating = $_POST['rating']; // 将评分插入到数据库中 $query = "INSERT INTO ratings (question_id, user_id, rating) VALUES ('$questionId', '$userId', '$rating')"; // 执行插入操作 if ($result) { // 评分成功,刷新页面或跳转回问题详情页 } else { // 评分失败,显示错误信息 } } ?> <!-- 评分组件 --> <form action="" method="POST"> <input type="hidden" name="rating" value="1"> <button type="submit">赞同</button> </form> <form action="" method="POST"> <input type="hidden" name="rating" value="-1"> <button type="submit">反对</button> </form>
為了使用戶能夠更好地瀏覽和搜尋問題,我們需要按照一定的規則對問題進行排序。常見的排序規則包括依照時間、熱門程度和評分值等進行排序。在這裡,我們以評分值高低作為排序規則。
<?php // 查询问题和评分表格,并按评分值降序排列 $query = "SELECT q.id, q.title, q.content, AVG(r.rating) AS average_rating FROM questions q LEFT JOIN ratings r ON q.id = r.question_id GROUP BY q.id ORDER BY average_rating DESC"; // 执行查询操作 while ($row = mysqli_fetch_assoc($result)) { // 显示问题列表 echo '<h3>' . $row['title'] . '</h3>'; echo '<p>' . $row['content'] . '</p>'; echo '<p>评分:' . $row['average_rating'] . '</p>'; } ?>
透過上述程式碼範例,我們展示如何使用PHP開發知識問答網站中的問題評分和排序功能。使用評分功能,使用者可以對問題進行評價,為其他使用者提供參考。而使用排序功能,使用者可以根據評分值高低來瀏覽和搜尋問題,快速找到高品質的答案。當然,在實際開發中還需考慮到安全性和效能最佳化等問題。希望本文能對PHP開發人員在開發知識問答網站中的問題評分和排序功能有所幫助。
以上是使用 PHP 開發知識問答網站中的問題評分和排序功能。的詳細內容。更多資訊請關注PHP中文網其他相關文章!