Maison  >  Article  >  développement back-end  >  PHP implémente les fonctions de nuage de tags et d'agrégation de sujets dans le site Web de questions et réponses de connaissances.

PHP implémente les fonctions de nuage de tags et d'agrégation de sujets dans le site Web de questions et réponses de connaissances.

WBOY
WBOYoriginal
2023-07-01 22:03:08796parcourir

PHP implémente les fonctions de nuage de tags et d'agrégation de sujets dans le site Web de questions et réponses de connaissances

Dans le site Web de questions et réponses de connaissances, le nuage de tags et l'agrégation de sujets sont deux fonctions importantes. Le nuage de balises peut aider les utilisateurs à comprendre rapidement les sujets d'actualité et les balises courantes sur le site Web, facilitant ainsi la navigation et la recherche de questions et réponses associées. L'agrégation de sujets peut regrouper les questions et les réponses avec les mêmes balises, offrant ainsi aux utilisateurs un moyen plus pratique de visualiser et de discuter. Ci-dessous, nous utiliserons PHP pour implémenter ces deux fonctions.

Tout d'abord, nous devons créer une base de données pour stocker les données des questions, des réponses et des tags. Vous pouvez créer une base de données nommée « qa » avec trois tables : questions, réponses et balises. La structure du tableau

questions est la suivante :

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;

le tableau des réponses est la suivante :

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;

le tableau des balises est la suivante :

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

Ensuite, nous devons ajouter des cases de sélection de balises sur la page de questions et la page de réponses de le site Web de questions et réponses de connaissances et associer des balises sélectionnées par l'utilisateur à des questions ou des réponses.

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

Ensuite, nous devons stocker les données de balise associées à la question ou à la réponse dans la base de données dans le gestionnaire de soumission de questions en arrière-plan (post_question.php) et le gestionnaire de soumission de réponses (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);
}

Nous avons désormais associé avec succès les balises sélectionnées par l'utilisateur aux questions et réponses. Ensuite, nous implémenterons les fonctions de nuage de tags et d’agrégation de sujets.

Tout d'abord, nous devons écrire une fonction PHP pour obtenir toutes les balises et leur nombre d'occurrences.

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

Ensuite, nous pouvons utiliser cette fonction sur la page front-end pour afficher le nuage de tags.

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

Enfin, nous pouvons implémenter la fonction d'agrégation de sujets, c'est-à-dire interroger des questions et des réponses liées en fonction de balises.

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

Nous pouvons utiliser les deux fonctions ci-dessus sur la page de détails du sujet pour afficher les questions et réponses associées.

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

Grâce aux exemples de code ci-dessus, nous avons implémenté avec succès les fonctions de nuage de balises et d'agrégation de sujets dans le site Web de questions et réponses de connaissances. Les utilisateurs peuvent facilement parcourir les sujets d'actualité et les questions et réponses associées. Dans le même temps, nous fournissons également des exemples d'opérations de base de données correspondants pour permettre aux lecteurs de mieux comprendre les idées de mise en œuvre du code. J'espère que cet article sera utile aux lecteurs dans le besoin.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn