**PHP 中操作数据库写入数据的全面指南**58


在 PHP 中,向数据库写入数据是一个至关重要的任务,因为它允许将信息持久化到永久存储中。本文将提供一个全面的指南,介绍如何在 PHP 中使用 MySQL、PostgreSQL 和 SQLite 等流行数据库向表中插入、更新和删除数据。

数据库连接

无论使用哪种数据库,第一步都是建立到数据库的连接。PHP 提供了多种可用的扩展,例如 MySQLi、PDO 和 SQLite3,具体取决于您要连接的数据库类型。
// MySQLi
$mysqli = new mysqli("localhost", "username", "password", "database");
// PDO (MySQL)
$dsn = "mysql:host=localhost;dbname=database";
$pdo = new PDO($dsn, "username", "password");
// SQLite3
$db = new SQLite3("");

插入数据

要向表中插入数据,可以使用 `INSERT INTO` 语句。该语句需要指定表名、要插入的列以及相应的列值。
// 插入数据到 MySQL 表
$query = "INSERT INTO users (name, email) VALUES ('John Doe', '@')";
$mysqli->query($query);
// 插入数据到 PostgreSQL 表
$query = "INSERT INTO users (name, email) VALUES ('John Doe', '@')";
$pdo->query($query);
// 插入数据到 SQLite 表
$query = "INSERT INTO users (name, email) VALUES ('John Doe', '@')";
$db->query($query);

更新数据

要更新表中的现有数据,可以使用 `UPDATE` 语句。该语句需要指定表名、要更新的列、新的值以及一个条件来标识要更新的行。
// 更新 MySQL 表中的数据
$query = "UPDATE users SET name = 'Jane Doe' WHERE id = 1";
$mysqli->query($query);
// 更新 PostgreSQL 表中的数据
$query = "UPDATE users SET name = 'Jane Doe' WHERE id = 1";
$pdo->query($query);
// 更新 SQLite 表中的数据
$query = "UPDATE users SET name = 'Jane Doe' WHERE id = 1";
$db->query($query);

删除数据

要从表中删除数据,可以使用 `DELETE` 语句。该语句需要指定表名和一个条件来标识要删除的行。
// 删除 MySQL 表中的数据
$query = "DELETE FROM users WHERE id = 1";
$mysqli->query($query);
// 删除 PostgreSQL 表中的数据
$query = "DELETE FROM users WHERE id = 1";
$pdo->query($query);
// 删除 SQLite 表中的数据
$query = "DELETE FROM users WHERE id = 1";
$db->query($query);

事务处理

在某些情况下,您可能需要在单个操作中执行多个查询。在这种情况下,可以使用事务处理来确保所有查询要么全部成功,要么全部失败。
// 开始一个事务
$mysqli->begin_transaction();
// 执行查询
$query1 = "INSERT INTO users (name, email) VALUES ('John Doe', '@')";
$mysqli->query($query1);
$query2 = "UPDATE users SET name = 'Jane Doe' WHERE id = 1";
$mysqli->query($query2);
// 提交事务(如果所有查询成功)
$mysqli->commit();

错误处理

在处理数据库操作时,错误处理至关重要。PHP 提供了多种方法来获取和处理错误。
// 使用 MySQLi 获取错误
if ($mysqli->error) {
echo "Error: " . $mysqli->error;
}
// 使用 PDO 获取错误
if ($pdo->errorCode()) {
$errorInfo = $pdo->errorInfo();
echo "Error: " . $errorInfo[2];
}
// 使用 SQLite3 获取错误
if ($db->lastErrorCode()) {
echo "Error: " . $db->lastErrorMsg();
}

结论

遵循本指南,您将能够使用 PHP 熟练地向数据库写入数据。通过充分利用 `INSERT INTO`、`UPDATE`、`DELETE` 和事务处理等语句,您可以轻松地管理数据库中的数据,从而构建强大的 Web 应用程序。

2024-12-08


上一篇:序列:在 PHP 中有效管理数据库中的递增 ID

下一篇:如何使用 PHP 获取 API 请求地址