在PHP中,实现增删改查(CRUD)操作通常涉及与数据库的交互。以下是一个简单的示例,展示如何使用PHP和MySQL来实现基本的增删改查操作。
首先,我们需要连接到MySQL数据库。
<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "testdb";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检查连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
?>
向数据库中插入新数据。
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$name = $_POST['name'];
$email = $_POST['email'];
$sql = "INSERT INTO users (name, email) VALUES ('$name', '$email')";
if ($conn->query($sql) === TRUE) {
echo "新记录插入成功";
} else {
echo "Error: " . $sql . "<br>" . $conn->error;
}
}
?>
<form method="post">
姓名: <input type="text" name="name"><br>
邮箱: <input type="text" name="email"><br>
<input type="submit" value="提交">
</form>
从数据库中查询数据并显示。
<?php
$sql = "SELECT id, name, email FROM users";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
// 输出每行数据
while($row = $result->fetch_assoc()) {
echo "id: " . $row["id"]. " - Name: " . $row["name"]. " - Email: " . $row["email"]. "<br>";
}
} else {
echo "0 结果";
}
?>
更新数据库中的现有数据。
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$id = $_POST['id'];
$name = $_POST['name'];
$email = $_POST['email'];
$sql = "UPDATE users SET name='$name', email='$email' WHERE id=$id";
if ($conn->query($sql) === TRUE) {
echo "记录更新成功";
} else {
echo "Error updating record: " . $conn->error;
}
}
?>
<form method="post">
ID: <input type="text" name="id"><br>
姓名: <input type="text" name="name"><br>
邮箱: <input type="text" name="email"><br>
<input type="submit" value="更新">
</form>
从数据库中删除数据。
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$id = $_POST['id'];
$sql = "DELETE FROM users WHERE id=$id";
if ($conn->query($sql) === TRUE) {
echo "记录删除成功";
} else {
echo "Error deleting record: " . $conn->error;
}
}
?>
<form method="post">
ID: <input type="text" name="id"><br>
<input type="submit" value="删除">
</form>
最后,记得关闭数据库连接。
<?php
$conn->close();
?>
以上代码展示了如何使用PHP和MySQL实现基本的增删改查操作。实际应用中,建议使用预处理语句(Prepared Statements)来防止SQL注入攻击,并考虑使用PDO或ORM(如Eloquent)来简化数据库操作。
希望这个示例对你有帮助!