首頁  >  文章  >  後端開發  >  使用 PHP 開發知識問答網站中的問題評分和排序功能。

使用 PHP 開發知識問答網站中的問題評分和排序功能。

PHPz
PHPz原創
2023-07-01 22:46:351417瀏覽

使用 PHP 開發知識問答網站中的問題評分和排序功能

隨著網路的發展,知識問答網站如今已成為人們獲取知識和解決問題的重要管道之一。這些網站給予使用者提問、回答和評論的自由,可是如何對問題進行評分和排序成為了一個關鍵的問題。本文將介紹如何使用PHP開發知識問答網站中的問題評分和排序功能。

  1. 資料庫設計

首先,我們需要在資料庫中建立相關的表格來儲存問題和評分資料。假設我們有兩個表格,一個是問題表格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
);
  1. 問題評分功能

在知識問答網站中,使用者可以對問題進行評分,以表達對問題的滿意程度。我們可以在問題詳情頁的下方新增一個評分元件,使用者可以透過點擊按鈕來對問題進行評分。

<?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>
  1. 問題排序功能

為了使用戶能夠更好地瀏覽和搜尋問題,我們需要按照一定的規則對問題進行排序。常見的排序規則包括依照時間、熱門程度和評分值等進行排序。在這裡,我們以評分值高低作為排序規則。

<?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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn