PHP を使用してオンライン Q&A およびナレッジ ベース機能を実装する方法
はじめに:
インターネットの普及と発展に伴い、ますます多くの人々がオンライン Q&A およびナレッジ ベース機能を実装しています。知識交換や助けを求めるためにインターネット プラットフォームを使用するため。オンライン Q&A およびナレッジ ベース機能は、ユーザーのニーズを満たすための重要な部分となっています。この記事では、PHP を使用して簡単なオンライン Q&A およびナレッジ ベース機能を実装する方法を紹介し、コード例を示します。
質問テーブル:
CREATE TABLE `questions` ( `id` int(11) NOT NULL AUTO_INCREMENT, `title` varchar(255) NOT NULL, `content` text NOT NULL, `author` varchar(255) NOT NULL, `created_at` datetime NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
回答テーブル:
CREATE TABLE `answers` ( `id` int(11) NOT NULL AUTO_INCREMENT, `question_id` int(11) NOT NULL, `content` text NOT NULL, `author` varchar(255) NOT NULL, `created_at` datetime NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
<!DOCTYPE html> <html> <head> <title>在线问答和知识库</title> <style> /* CSS 样式 */ </style> </head> <body> <h1>在线问答和知识库</h1> <h2>问题列表</h2> <ul> <?php // 使用 PHP 查询数据库并显示问题列表 $db = new PDO('mysql:host=localhost;dbname=QAKB;charset=utf8', 'username', 'password'); $stmt = $db->query('SELECT * FROM questions ORDER BY created_at DESC'); while ($question = $stmt->fetch()) { echo '<li><a href="question.php?id=' . $question['id'] . '">' . $question['title'] . '</a></li>'; } ?> </ul> <h2>提交问题</h2> <form action="submit_question.php" method="POST"> <label for="question_title">问题标题:</label> <input type="text" name="question_title" id="question_title"> <label for="question_content">问题内容:</label> <textarea name="question_content" id="question_content"></textarea> <input type="submit" value="提交问题"> </form> </body> </html>
<?php // 提交问题的后台处理代码(submit_question.php) $db = new PDO('mysql:host=localhost;dbname=QAKB;charset=utf8', 'username', 'password'); $title = $_POST['question_title']; $content = $_POST['question_content']; $author = '用户'; // 假设用户登录后可以获取用户名 $stmt = $db->prepare('INSERT INTO questions (title, content, author, created_at) VALUES (?, ?, ?, ?)'); $stmt->execute([$title, $content, $author, date('Y-m-d H:i:s')]); header('Location: index.php'); // 提交问题后返回问题列表页 exit; ?> <?php // 查看问题及回答的详细页面(question.php) $db = new PDO('mysql:host=localhost;dbname=QAKB;charset=utf8', 'username', 'password'); $question_id = $_GET['id']; $stmt = $db->prepare('SELECT * FROM questions WHERE id = ?'); $stmt->execute([$question_id]); $question = $stmt->fetch(); $stmt = $db->prepare('SELECT * FROM answers WHERE question_id = ?'); $stmt->execute([$question_id]); $answers = $stmt->fetchAll(); ?> <!DOCTYPE html> <html> <head> <title><?php echo $question['title']; ?></title> <style> /* CSS 样式 */ </style> </head> <body> <h1><?php echo $question['title']; ?></h1> <p><?php echo $question['content']; ?></p> <p>提问者:<?php echo $question['author']; ?></p> <p>提问时间:<?php echo $question['created_at']; ?></p> <h2>回答问题</h2> <form action="submit_answer.php" method="POST"> <input type="hidden" name="question_id" value="<?php echo $question_id; ?>"> <textarea name="answer_content"></textarea> <input type="submit" value="提交回答"> </form> <h2>回答列表</h2> <ul> <?php foreach ($answers as $answer): ?> <li> <p><?php echo $answer['content']; ?></p> <p>回答者:<?php echo $answer['author']; ?></p> <p>回答时间:<?php echo $answer['created_at']; ?></p> </li> <?php endforeach; ?> </ul> </body> </html>
結論:
上記のデータベース設計とコード実装を通じて、簡単なオンライン質問と回答およびナレッジ ベース機能を作成できます。ユーザーは、質問を投稿したり、質問に回答したりすることで、知識の共有と交換を実現します。もちろん、より複雑な機能が必要な場合は、ニーズに応じて拡張および最適化できます。この記事が、PHP を使用してオンライン Q&A およびナレッジ ベース機能を実装する方法を理解するのに役立つことを願っています。
以上がPHP を使用してオンライン Q&A およびナレッジ ベース機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。