上一篇                     
               
			  PHP如何连接MySQL数据库
- 数据库
- 2025-06-10
- 2973
 在PHP中选择数据库,使用MySQLi时调用
 
 
mysqli_select_db($connection, "db_name")函数,或通过PDO在连接字符串中直接指定数据库名,确保先建立有效数据库连接再执行操作。
在PHP中连接并选择数据库是Web开发的基础操作,正确实现能确保数据交互的安全高效,以下是两种主流方法的详细代码示例和最佳实践:
MySQLi扩展(推荐面向对象方式)
MySQLi支持面向对象和面向过程两种写法,优先推荐面向对象风格。

面向对象写法
<?php
$servername = "localhost";  // 数据库服务器地址
$username = "your_username"; // 数据库用户名
$password = "your_password"; // 数据库密码
$dbname = "target_database"; // 目标数据库名
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检测连接
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}
echo "成功连接到数据库: " . $dbname;
// 后续SQL操作(示例)
$sql = "SELECT id FROM users";
$result = $conn->query($sql);
// 关闭连接(非必须,脚本结束自动关闭)
$conn->close();
?> 
关键点:
- 通过new mysqli()构造函数直接指定数据库名。
- connect_error属性检测连接状态,避免静默失败。
- 始终验证连接后再执行查询,防止未定义行为。
面向过程写法
<?php
$servername = "localhost";
$username = "your_username";
$password = "your_password";
$dbname = "target_database";
// 创建连接
$conn = mysqli_connect($servername, $username, $password, $dbname);
// 检测连接
if (!$conn) {
    die("连接失败: " . mysqli_connect_error());
}
echo "数据库选择成功";
mysqli_close($conn); // 关闭连接
?> 
PDO扩展(支持多数据库)
PDO提供统一的接口,适合需要兼容多种数据库(如MySQL、PostgreSQL)的项目。

<?php
$servername = "localhost";
$username = "your_username";
$password = "your_password";
$dbname = "target_database";
try {
    // 创建PDO实例并指定数据库
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
    // 设置错误模式为异常捕获
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    echo "PDO连接数据库成功";
    // 示例查询(使用预处理防SQL注入)
    $stmt = $conn->prepare("SELECT * FROM products WHERE category = :cat");
    $stmt->bindValue(':cat', 'electronics');
    $stmt->execute();
} catch(PDOException $e) {
    die("错误: " . $e->getMessage()); // 生产环境应记录日志而非直接输出
}
$conn = null; // 关闭连接
?> 
核心优势:
- try/catch异常处理提升健壮性。
- 预处理语句(prepare()+bindValue())彻底防御SQL注入。
- 灵活的ATTR_ERRMODE配置简化调试。
关键安全实践
- 禁用明文密码 
  - 使用环境变量(如getenv('DB_PASSWORD'))存储密码,避免代码硬编码。
 
- 使用环境变量(如
- 错误处理 
  - 生产环境关闭错误显示:ini_set('display_errors', 0);
- 记录日志到文件:error_log("Database error", 3, "/path/to/errors.log");
 
- 生产环境关闭错误显示:
- 连接复用 通过单例模式或依赖注入管理连接,避免重复创建开销。 
选择建议
| 场景 | 推荐方式 | 
|---|---|
| 纯MySQL项目 | MySQLi面向对象 | 
| 多数据库支持需求 | PDO | 
| 遗留系统维护 | MySQLi面向过程 | 
官方文档参考:
- MySQLi文档
- PDO文档
本文代码遵循PHP 7.4+语法规范,已通过PHPStan静态检测,实际部署时请替换your_username等占位符,并在生产环境配置SSL加密连接。
 
 
 
			