Rumah  >  Artikel  >  pembangunan bahagian belakang  >  PHP melaksanakan awan teg dan fungsi pengagregatan topik dalam tapak web soal jawab pengetahuan.

PHP melaksanakan awan teg dan fungsi pengagregatan topik dalam tapak web soal jawab pengetahuan.

WBOY
WBOYasal
2023-07-01 22:03:08793semak imbas

PHP melaksanakan awan teg dan fungsi pengagregatan topik dalam laman web soalan dan jawapan pengetahuan

Dalam laman web soal jawab pengetahuan, awan teg dan pengagregatan topik adalah dua fungsi penting. Awan teg boleh membantu pengguna memahami topik hangat dan teg biasa dengan cepat di tapak web, menjadikannya lebih mudah untuk pengguna menyemak imbas dan mencari soalan dan jawapan yang berkaitan. Pengagregatan topik boleh mengumpulkan soalan dan jawapan dengan teg yang sama bersama-sama, memberikan pengguna cara yang lebih mudah untuk melihat dan berbincang. Di bawah ini kita akan menggunakan PHP untuk melaksanakan kedua-dua fungsi ini.

Pertama, kita perlu mencipta pangkalan data untuk menyimpan data soalan, jawapan dan tag. Anda boleh mencipta pangkalan data bernama "qa" yang mengandungi tiga jadual: soalan, jawapan dan teg. Struktur jadual

soalan adalah seperti berikut:

CREATE TABLE `questions` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) DEFAULT '',
  `content` text,
  `date` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

jadual jawapan adalah seperti berikut:

CREATE TABLE `answers` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `question_id` int(11) DEFAULT NULL,
  `content` text,
  `date` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

jadual tag adalah seperti berikut:

CREATE TABLE `tags` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Seterusnya, kita perlu menambah kotak pilihan tag pada halaman soalan dan halaman jawapan tapak web soal jawab pengetahuan, dan kaitkan tag yang dipilih pengguna dengan soalan atau jawapan.

<!-- 提问页面 -->
<form action="post_question.php" method="post">
  <label for="title">问题标题:</label>
  <input type="text" name="title" id="title"><br>

  <label for="content">问题内容:</label>
  <textarea name="content" id="content"></textarea><br>

  <label for="tags">标签:</label>
  <select name="tags[]" id="tags" multiple>
    <option value="php">PHP</option>
    <option value="javascript">JavaScript</option>
    <option value="html">HTML</option>
    <!-- 其他标签选项 -->
  </select><br>

  <input type="submit" value="提交问题">
</form>

<!-- 回答页面 -->
<form action="post_answer.php" method="post">
  <label for="content">回答内容:</label>
  <textarea name="content" id="content"></textarea><br>

  <label for="tags">标签:</label>
  <select name="tags[]" id="tags" multiple>
    <option value="php">PHP</option>
    <option value="javascript">JavaScript</option>
    <option value="html">HTML</option>
    <!-- 其他标签选项 -->
  </select><br>

  <input type="submit" value="提交回答">
</form>

Kemudian, kita perlu menyimpan data tag yang dikaitkan dengan soalan atau jawapan ke dalam pangkalan data dalam pengendali penyerahan soalan latar belakang (post_question.php) dan pengendali penyerahan jawapan (post_answer.php).

// post_question.php
// 获取用户提交的问题数据
$title = $_POST['title'];
$content = $_POST['content'];
$tags = $_POST['tags'];

// 插入问题数据到 questions 表中
// 获取最后插入的问题的id
$question_id = mysqli_insert_id($conn);

// 插入标签数据到 tags 表中
foreach ($tags as $tag) {
  $sql = "INSERT INTO tags (title) VALUES ('$tag')";
  mysqli_query($conn, $sql);
  
  // 获取最后插入的标签的id
  $tag_id = mysqli_insert_id($conn);
  
  // 插入问题和标签的关联到 question_tag 表中
  $sql = "INSERT INTO question_tag (question_id, tag_id) VALUES ($question_id, $tag_id)";
  mysqli_query($conn, $sql);
}

// post_answer.php
// 获取用户提交的回答数据
$content = $_POST['content'];
$tags = $_POST['tags'];

// 插入回答数据到 answers 表中
// 获取最后插入的回答的id
$answer_id = mysqli_insert_id($conn);

// 插入标签数据到 tags 表中
foreach ($tags as $tag) {
  $sql = "INSERT INTO tags (title) VALUES ('$tag')";
  mysqli_query($conn, $sql);
  
  // 获取最后插入的标签的id
  $tag_id = mysqli_insert_id($conn);
  
  // 插入回答和标签的关联到 answer_tag 表中
  $sql = "INSERT INTO answer_tag (answer_id, tag_id) VALUES ($answer_id, $tag_id)";
  mysqli_query($conn, $sql);
}

Kini kami telah berjaya mengaitkan teg yang dipilih pengguna dengan soalan dan jawapan. Seterusnya, kami akan melaksanakan awan teg dan fungsi pengagregatan topik.

Pertama, kita perlu menulis fungsi PHP untuk mendapatkan semua teg dan bilangan kejadiannya.

function getTagsCloud() {
  global $conn;
  
  // 查询所有标签及其出现次数
  $sql = "SELECT title, COUNT(*) AS count FROM tags GROUP BY title";
  $result = mysqli_query($conn, $sql);
  
  $tagsCloud = array();
  while ($row = mysqli_fetch_assoc($result)) {
    $tagsCloud[$row['title']] = $row['count'];
  }
  
  return $tagsCloud;
}

Kemudian, kita boleh menggunakan fungsi ini pada halaman hujung hadapan untuk memaparkan awan tag.

<?php
// 获取标签云数据
$tagsCloud = getTagsCloud();
?>

<!-- 标签云 -->
<div class="tag-cloud">
  <?php foreach ($tagsCloud as $tag => $count): ?>
    <a href="search.php?tag=<?php echo $tag; ?>"><?php echo $tag; ?></a>
  <?php endforeach; ?>
</div>

Akhir sekali, kita boleh melaksanakan fungsi pengagregatan topik, iaitu soalan dan jawapan berkaitan pertanyaan berdasarkan tag.

function getQuestionsByTag($tag) {
  global $conn;
  
  // 根据标签获取问题
  $sql = "SELECT q.id, q.title, q.date, COUNT(*) AS answersCount 
          FROM questions q 
          INNER JOIN question_tag qt ON q.id = qt.question_id 
          INNER JOIN tags t ON t.id = qt.tag_id 
          WHERE t.title = '$tag' 
          GROUP BY q.id";
  $result = mysqli_query($conn, $sql);
  
  $questions = array();
  while ($row = mysqli_fetch_assoc($result)) {
    $questions[] = $row;
  }
  
  return $questions;
}

function getAnswersByTag($tag) {
  global $conn;
  
  // 根据标签获取回答
  $sql = "SELECT a.id, a.content, a.date, q.title 
          FROM answers a 
          INNER JOIN answer_tag at ON a.id = at.answer_id 
          INNER JOIN tags t ON t.id = at.tag_id 
          INNER JOIN questions q ON q.id = a.question_id 
          WHERE t.title = '$tag'";
  $result = mysqli_query($conn, $sql);
  
  $answers = array();
  while ($row = mysqli_fetch_assoc($result)) {
    $answers[] = $row;
  }
  
  return $answers;
}

Kita boleh menggunakan dua fungsi di atas pada halaman butiran topik untuk memaparkan soalan dan jawapan yang berkaitan.

<?php
// 获取标签名称
$tag = $_GET['tag'];

// 获取话题相关的问题和回答数据
$questions = getQuestionsByTag($tag);
$answers = getAnswersByTag($tag);
?>

<!-- 话题相关的问题 -->
<?php foreach ($questions as $question): ?>
  <div class="question">
    <h3><?php echo $question['title']; ?></h3>
    <p>回答数量: <?php echo $question['answersCount']; ?></p>
    <!-- 其他问题信息展示 -->
  </div>
<?php endforeach; ?>

<!-- 话题相关的回答 -->
<?php foreach ($answers as $answer): ?>
  <div class="answer">
    <h4><?php echo $answer['title']; ?></h4>
    <p><?php echo $answer['content']; ?></p>
    <!-- 其他回答信息展示 -->
  </div>
<?php endforeach; ?>

Melalui contoh kod di atas, kami telah berjaya melaksanakan fungsi awan teg dan pengagregatan topik dalam tapak web Soal Jawab pengetahuan Pengguna boleh melayari topik hangat serta soalan serta jawapan yang berkaitan. Pada masa yang sama, kami juga menyediakan contoh operasi pangkalan data yang sepadan untuk membolehkan pembaca memahami dengan lebih baik idea pelaksanaan kod tersebut. Semoga artikel ini dapat membantu pembaca yang memerlukan.

Atas ialah kandungan terperinci PHP melaksanakan awan teg dan fungsi pengagregatan topik dalam tapak web soal jawab pengetahuan.. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn