首先确认PHP与MySQL已安装并启用相应扩展,然后创建测试数据库和用户,最后通过MySQLi过程式、MySQLi对象式和PDO三种方式依次验证连接,确保PHP能正确访问MySQL数据库。

如果您尝试在Web服务器上运行PHP脚本,但无法从MySQL数据库获取数据,则可能是由于PHP与MySQL之间的连接未正确配置。以下是建立和验证PHP与MySQL连接的详细步骤。
本文运行环境:Dell XPS 13,Windows 11
一、确认PHP与MySQL环境已安装
在进行连接配置之前,必须确保PHP和MySQL服务均已正确安装并可运行。可通过命令行工具检查服务状态,并确认PHP支持MySQL扩展。
1、打开命令提示符,输入php -v,查看PHP版本信息以确认安装成功。
立即学习“PHP免费学习笔记(深入)”;
2、输入mysql --version,验证MySQL客户端是否已安装。
3、检查php.ini配置文件中是否启用mysqli或PDO扩展,查找并取消注释以下任意一行:extension=mysqli 或 extension=pdo_mysql。
4、重启Web服务器(如Apache)使配置生效。
二、创建测试用的MySQL数据库与用户
为避免使用高权限账户进行连接测试,建议创建专用数据库和用户账号,提高安全性。
1、登录MySQL命令行或使用管理工具(如phpMyAdmin),执行语句创建数据库:CREATE DATABASE test_db CHARACTER SET utf8mb4;
2、创建专用用户并设置密码:CREATE USER 'test_user'@'localhost' IDENTIFIED BY 'StrongPassword123!';
3、授予该用户对test_db的全部权限:GRANT ALL PRIVILEGES ON test_db.* TO 'test_user'@'localhost';
4、刷新权限表使更改立即生效:FLUSH PRIVILEGES;
三、使用MySQLi面向过程方式连接数据库
MySQLi扩展提供面向过程和面向对象两种编程接口,适合不同开发习惯。此方法适用于简单脚本或传统项目。
1、创建名为connect_mysqli_procedural.php的文件,写入以下代码:
$conn = mysqli_connect("localhost", "test_user", "StrongPassword123!", "test_db");
if (!$conn) {
die("连接失败: " . mysqli_connect_error());
}
echo "MySQLi过程式连接成功";
?>
2、将文件放置于Web服务器根目录(如htdocs),通过浏览器访问该文件。
3、若页面显示“MySQLi过程式连接成功”,则表示连接正常;否则根据错误信息排查问题。
四、使用MySQLi面向对象方式连接数据库
面向对象方式更符合现代PHP开发规范,代码结构清晰,便于维护和扩展。
1、创建文件connect_mysqli_oop.php,写入如下代码:
$conn = new mysqli("localhost", "test_user", "StrongPassword123!", "test_db");
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
echo "MySQLi对象式连接成功";
?>
2、保存文件并部署到Web服务器目录中。
3、通过浏览器访问该文件,验证输出结果是否为预期的成功提示。
五、使用PDO方式建立数据库连接
PDO(PHP Data Objects)提供统一接口访问多种数据库,具备更好的可移植性和预处理支持,推荐用于新项目开发。
1、创建文件connect_pdo.php,写入以下代码:
try {
$dsn = "mysql:host=localhost;dbname=test_db;charset=utf8mb4";
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
];
$pdo = new PDO($dsn, 'test_user', 'StrongPassword123!', $options);
echo "PDO连接成功";
} catch (PDOException $e) {
die("PDO连接失败: " . $e->getMessage());
}
?>
2、将文件上传至Web服务器可访问路径。
3、通过浏览器请求该文件,确认是否输出“PDO连接成功”消息。











