Heim >Backend-Entwicklung >PHP-Tutorial >PHP implementiert die Tag-Cloud- und Themenaggregationsfunktionen in der Wissensfrage- und -antwort-Website.

PHP implementiert die Tag-Cloud- und Themenaggregationsfunktionen in der Wissensfrage- und -antwort-Website.

WBOY
WBOYOriginal
2023-07-01 22:03:08834Durchsuche

PHP implementiert die Tag-Cloud- und Themen-Aggregationsfunktionen in der Wissens-Frage-und-Antwort-Website.

In der Wissens-Fragen-und-Antwort-Website sind Tag-Cloud und Themen-Aggregation zwei wichtige Funktionen. Die Tag-Cloud kann Benutzern dabei helfen, aktuelle Themen und häufig verwendete Tags auf der Website schnell zu verstehen, sodass Benutzer leichter nach verwandten Fragen und Antworten suchen können. Durch die Themenaggregation können Fragen und Antworten mit denselben Tags gruppiert werden, was Benutzern eine bequemere Möglichkeit zum Anzeigen und Diskutieren bietet. Im Folgenden werden wir PHP verwenden, um diese beiden Funktionen zu implementieren.

Zuerst müssen wir eine Datenbank erstellen, um die Daten von Fragen, Antworten und Tags zu speichern. Sie können eine Datenbank mit dem Namen „qa“ erstellen, die drei Tabellen enthält: Fragen, Antworten und Tags. Die Struktur der

Fragentabelle ist wie folgt:

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;

Antwortentabelle ist wie folgt:

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;

Tags-Tabelle ist wie folgt:

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

Als nächstes müssen wir Tag-Auswahlfelder auf der Fragenseite und der Antwortseite hinzufügen B. auf der Wissens-Frage-und-Antwort-Website, und verknüpfen Sie vom Benutzer ausgewählte Tags mit Fragen oder Antworten.

<!-- 提问页面 -->
<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>

Dann müssen wir die Tag-Daten, die mit der Frage oder Antwort verknüpft sind, in der Datenbank im Hintergrund-Handler für die Übermittlung von Fragen (post_question.php) und im Handler für die Übermittlung von Antworten (post_answer.php) speichern.

// 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);
}

Jetzt haben wir die vom Benutzer ausgewählten Tags erfolgreich mit Fragen und Antworten verknüpft. Als Nächstes implementieren wir die Tag-Cloud- und Themenaggregationsfunktionen.

Zuerst müssen wir eine PHP-Funktion schreiben, um alle Tags und deren Häufigkeit abzurufen.

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;
}

Dann können wir diese Funktion auf der Frontend-Seite verwenden, um die Tag-Cloud anzuzeigen.

<?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>

Endlich können wir die Themenaggregationsfunktion implementieren, also verwandte Fragen und Antworten basierend auf Tags abfragen.

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;
}

Wir können die beiden oben genannten Funktionen auf der Themendetailseite verwenden, um verwandte Fragen und Antworten anzuzeigen.

<?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; ?>

Durch die oben genannten Codebeispiele haben wir die Tag-Cloud- und Themenaggregationsfunktionen erfolgreich in der Wissensfrage- und -antworten-Website implementiert. Benutzer können problemlos aktuelle Themen und verwandte Fragen und Antworten durchsuchen. Gleichzeitig stellen wir auch entsprechende Datenbankbetriebsbeispiele bereit, damit die Leser die Implementierungsideen des Codes besser verstehen können. Ich hoffe, dass dieser Artikel für Leser in Not hilfreich sein wird.

Das obige ist der detaillierte Inhalt vonPHP implementiert die Tag-Cloud- und Themenaggregationsfunktionen in der Wissensfrage- und -antwort-Website.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn