PHP 實現知識問答網站中的問題答案編輯和刪除功能
在知識問答網站中,為了保證問題和答案的質量,用戶經常需要對已經發布的問題和答案進行編輯和刪除操作。 PHP 是一種常用的後端程式語言,具備強大的處理資料和資料庫操作的能力,非常適合用來實現這些功能。本文將介紹如何使用 PHP 實作知識問答網站中的問題答案編輯和刪除功能。
一、資料庫設計
首先,我們需要設計一個資料庫來儲存問題和答案的資訊。假設我們需要儲存問題的標題、內容和發佈時間,以及答案的內容和發佈時間。我們可以建立一個名為 "questions" 的表來儲存問題的訊息,並建立一個名為 "answers" 的表格來儲存答案的資訊。
questions 表的設計如下:
##CREATE TABLE questions (id INT AUTO_INCREMENT PRIMARY KEY, title VARCHAR(255) NOT NULL, content TEXT NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
id INT AUTO_INCREMENT PRIMARY KEY, question_id INT NOT NULL, content TEXT NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, FOREIGN KEY (question_id) REFERENCES questions(id) ON DELETE CASCADE
<?php // 获取用户提交的问题内容 $title = $_POST['title']; $content = $_POST['content']; // 连接数据库 $pdo = new PDO('mysql:host=localhost;dbname=your_database_name', 'your_username', 'your_password'); // 编辑问题 $id = $_POST['question_id']; $stmt = $pdo->prepare("UPDATE questions SET title=?, content=? WHERE id=?"); $stmt->execute([$title, $content, $id]); // 跳转回问题详情页 header("Location: question.php?id=$id"); exit; ?>
<?php // 获取用户提交的问题或答案 ID $id = $_GET['id']; // 连接数据库 $pdo = new PDO('mysql:host=localhost;dbname=your_database_name', 'your_username', 'your_password'); if (isset($_GET['question'])) { // 删除问题及其关联的答案 $stmt = $pdo->prepare("DELETE FROM questions WHERE id=?"); $stmt->execute([$id]); } else { // 删除答案 $stmt = $pdo->prepare("DELETE FROM answers WHERE id=?"); $stmt->execute([$id]); } // 跳转回问题详情页 header("Location: question.php"); exit; ?>
以上是PHP 實作知識問答網站中的問題答案編輯和刪除功能。的詳細內容。更多資訊請關注PHP中文網其他相關文章!