PHP 数据库连接的常见问题和解决方法有:连接失败:检查连接信息和 MySQL 服务状态;查询失败:检查查询语法、表和字段,以及连接有效性;插入、更新、删除失败:检查 SQL 语句、目标表和字段,以及连接有效性;数据库连接泄露:显式关闭连接或使用 try...catch...finally 块。
PHP数据库连接的常见问题及解决方法
一、连接失败
问题 1:mysqli_connect()
返回 false
$conn = mysqli_connect("localhost", "username", "password", "database"); if (!$conn) { echo "连接失败:" . mysqli_connect_error(); }
解决方法:
问题 2:PDO::__construct()
抛出异常
$dsn = "mysql:host=localhost;dbname=database"; $conn = new PDO($dsn, "username", "password");
解决方法:
二、查询失败
问题 1:mysqli_query()
返回 false
$query = "SELECT * FROM users"; $result = mysqli_query($conn, $query); if (!$result) { echo "查询失败:" . mysqli_error($conn); }
解决方法:
问题 2:PDOStatement::execute() 抛出异常
$stmt = $conn->prepare($query); $stmt->execute();
解决方法:
三、插入、更新、删除失败
问题:mysqli_affected_rows()
或 PDOStatement::rowCount()
返回 0
解决方法:
四、其他问题
问题:数据库连接泄露
解决方法:
mysqli_close()
或 PDO::close()
显式关闭连接。try...catch...finally
块确保连接在任何情况下都已关闭。实战案例
连接到 MySQL 数据库
// PHP >= 8.0,推荐使用 PDO $dsn = "mysql:host=localhost;dbname=database"; $conn = new PDO($dsn, "username", "password"); // PHP < 8.0,使用 mysqli_connect() $conn = mysqli_connect("localhost", "username", "password", "database");
查询数据库
// PDO $stmt = $conn->prepare("SELECT * FROM users WHERE id = ?"); $stmt->execute([$id]); $result = $stmt->fetchAll(); // mysqli $query = "SELECT * FROM users WHERE id = " . $id; $result = mysqli_query($conn, $query); $result = mysqli_fetch_all($result);
以上是PHP数据库连接的常见问题及解决方法的详细内容。更多信息请关注PHP中文网其他相关文章!