>  기사  >  백엔드 개발  >  PHP를 사용하여 퀴즈 웹사이트에서 질문 채점 및 정렬 기능을 개발했습니다.

PHP를 사용하여 퀴즈 웹사이트에서 질문 채점 및 정렬 기능을 개발했습니다.

PHPz
PHPz원래의
2023-07-01 22:46:351406검색

PHP를 사용하여 지식 Q&A 사이트의 질문 채점 및 정렬 기능을 개발하세요

인터넷의 발달과 함께 지식 Q&A 사이트는 이제 사람들이 지식을 얻고 문제를 해결하는 중요한 채널 중 하나가 되었습니다. 이러한 웹사이트는 사용자에게 질문하고 답변하고 의견을 제시할 자유를 제공하지만 질문에 점수를 매기고 순위를 매기는 방법이 중요한 문제가 됩니다. 이 기사에서는 PHP를 사용하여 지식 질문 및 답변 웹사이트에서 질문 채점 및 정렬 기능을 개발하는 방법을 소개합니다.

  1. 데이터베이스 디자인

먼저, 문제와 채점 데이터를 저장하기 위해 데이터베이스에 관련 테이블을 만들어야 합니다. 두 개의 테이블이 있다고 가정합니다. 하나는 질문 ID, 제목, 내용과 같은 필드가 포함된 질문 테이블이고 다른 하나는 등급 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 개발자가 지식 Q&A 웹사이트에서 질문 채점 및 정렬 기능을 개발하는 데 도움이 되기를 바랍니다.

위 내용은 PHP를 사용하여 퀴즈 웹사이트에서 질문 채점 및 정렬 기능을 개발했습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.