PHP를 사용하여 지식 Q&A 사이트의 질문 채점 및 정렬 기능을 개발하세요
인터넷의 발달과 함께 지식 Q&A 사이트는 이제 사람들이 지식을 얻고 문제를 해결하는 중요한 채널 중 하나가 되었습니다. 이러한 웹사이트는 사용자에게 질문하고 답변하고 의견을 제시할 자유를 제공하지만 질문에 점수를 매기고 순위를 매기는 방법이 중요한 문제가 됩니다. 이 기사에서는 PHP를 사용하여 지식 질문 및 답변 웹사이트에서 질문 채점 및 정렬 기능을 개발하는 방법을 소개합니다.
먼저, 문제와 채점 데이터를 저장하기 위해 데이터베이스에 관련 테이블을 만들어야 합니다. 두 개의 테이블이 있다고 가정합니다. 하나는 질문 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 );
지식질문답변사이트에서는 사용자가 질문에 대한 만족도를 평가하여 표현할 수 있습니다. 질문 세부 정보 페이지 하단에 평가 구성 요소를 추가할 수 있으며 사용자는 버튼을 클릭하여 질문을 평가할 수 있습니다.
<?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 개발자가 지식 Q&A 웹사이트에서 질문 채점 및 정렬 기능을 개발하는 데 도움이 되기를 바랍니다.
위 내용은 PHP를 사용하여 퀴즈 웹사이트에서 질문 채점 및 정렬 기능을 개발했습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!