答案:PHP连接MySQL需准备环境并选择MySQLi或PDO方式。1. 确保PHP与MySQL运行正常;2. MySQLi过程式用mysqli_connect()函数连接;3. MySQLi对象式通过new mysqli()创建连接;4. PDO使用new PDO()并设置异常模式更安全;5. 推荐使用PDO,配合预处理和配置文件提升安全性与可维护性。
PHP连接MySQL数据库是动态网站开发的基础操作。下面介绍使用mysqli和PDO两种主流方式连接MySQL的完整步骤与代码示例,适用于PHP 7及以上版本。
1. 确保环境准备就绪
在开始前,请确认以下几点:
- 已安装PHP环境(如XAMPP、WAMP或LNMP)
- MySQL服务正在运行
- 知道数据库名、用户名、密码和主机地址(通常是localhost)
2. 使用MySQLi扩展连接(面向过程)
这是最简单直接的方式,适合初学者。
$host = 'localhost';
$username = 'root';
$password = '';
$dbname = 'test_db';
// 创建连接
$conn = mysqli_connect($host, $username, $password, $dbname);
// 检查连接
if (!$conn) {
die('连接失败: ' . mysqli_connect_error());
}
echo '成功连接到MySQL数据库!';
3. 使用MySQLi扩展连接(面向对象)
更推荐使用面向对象的方式,结构更清晰。
$host = 'localhost';
$username = 'root';
$password = '';
$dbname = 'test_db';
// 创建连接对象
$conn = new mysqli($host, $username, $password, $dbname);
// 检查连接
if ($conn->connect_error) {
die('连接失败: ' . $conn->connect_error);
}
echo 'MySQLi面向对象连接成功!';
4. 使用PDO连接(推荐方式)
PDO支持多种数据库,安全性更高,适合项目长期维护。
$host = 'localhost'; $dbname = 'test_db'; $username = 'root'; $password = ''; try { $pdo = new PDO("mysql:host=$host;dbname=$dbname", $username, $password); // 设置PDO错误模式为异常 $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); echo 'PDO连接成功!'; } catch (PDOException $e) { die('连接失败: ' . $e->getMessage()); }
5. 安全建议与最佳实践
实际开发中应注意以下几点:
- 不要在代码中硬写数据库密码,可使用配置文件或环境变量
- 使用预处理语句防止SQL注入(特别是用户输入数据)
- 连接完成后及时关闭资源(一般PHP会自动处理)
- 生产环境关闭错误显示,避免泄露敏感信息

t = 'localhost';
$dbname = 'test_db';
$username = 'root';
$password = '';
try {
$pdo = new PDO("mysql:host=$host;dbname=$dbname", $username, $password);
// 设置PDO错误模式为异常
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
echo 'PDO连接成功!';
} catch (PDOException $e) {
die('连接失败: ' . $e->getMessage());
}







