登录
首页 >  文章 >  php教程

PHP连接MySQL数据库的简单示例代码如下:<?php//数据库配置信息$servername="localhost";//数据库服务器地址$username="root";//数据库用户名$password="";//数据库密码$dbname="my_database";//数据库名称//创建连接$conn=newmysqli($servername,$username,$passwor

时间:2026-03-24 16:19:38 486浏览 收藏

本文详细解析了PHP连接MySQL数据库的三种主流方式——mysqli面向对象、mysqli过程式和PDO扩展,不仅提供了清晰可复用的代码示例,还深入指出连接失败最常见的原因(如主机、用户名、密码或数据库名配置错误),并强调必须通过实际查询(如SELECT 1)验证连接的有效性,而非仅依赖连接对象创建成功;无论你是初学者还是需要兼容多数据库的进阶开发者,都能从中快速掌握稳定、安全、符合现代实践的数据库连接方法。

php和mysql怎么连接_php连接mysql数据库代码示例【连接】

如果您尝试在PHP中连接MySQL数据库,但连接失败,则可能是由于数据库主机地址、用户名、密码或数据库名称配置错误。以下是实现PHP与MySQL数据库连接的多种方法:

一、使用mysqli面向对象方式连接

mysqli扩展提供了面向对象和过程两种接口,面向对象方式更符合现代PHP开发习惯,支持预处理语句和更多高级特性。

1、确保PHP已启用mysqli扩展,在php.ini中确认存在extension=mysqli且未被注释。

2、在PHP文件中声明连接参数:$host = 'localhost'; $username = 'root'; $password = ''; $database = 'testdb';

3、创建mysqli对象并传入连接参数:$conn = new mysqli($host, $username, $password, $database);

4、检查连接是否成功:if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); }

二、使用mysqli过程方式连接

过程式调用适用于较老项目或习惯C风格编程的开发者,函数命名统一以mysqli_开头,参数顺序需严格遵循文档要求。

1、调用mysqli_connect函数并传入主机、用户、密码、数据库名:$conn = mysqli_connect('localhost', 'root', '', 'testdb');

2、使用mysqli_connect_error判断是否出错:if (!$conn) { die("连接失败: " . mysqli_connect_error()); }

3、设置字符集为utf8mb4以支持完整Unicode:mysqli_set_charset($conn, "utf8mb4");

三、使用PDO方式连接

PDO(PHP Data Objects)是数据库访问抽象层,支持多种数据库驱动,具备预处理、异常处理和命名参数等优势,适合需要兼容不同数据库的项目。

1、确认php.ini中已启用pdo和pdo_mysql扩展:extension=pdoextension=pdo_mysql

2、定义DSN(数据源名称),包含数据库类型、主机、端口、数据库名:$dsn = "mysql:host=localhost;dbname=testdb;charset=utf8mb4";

3、使用PDO构造函数连接,并设置错误模式为异常:$pdo = new PDO($dsn, 'root', '', [PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]);

四、验证连接状态的操作

无论采用哪种连接方式,都应通过具体查询操作验证连接是否真正可用,而不仅依赖连接对象创建成功与否。

1、执行一条简单SELECT语句测试连通性:$result = $conn->query("SELECT 1");(mysqli对象方式)

2、若使用PDO,可执行:$stmt = $pdo->query("SELECT 1");

3、检查返回结果是否非空:if ($result) { echo "连接验证通过"; }

本篇关于《PHP连接MySQL数据库的简单示例代码如下:connect_error){die("连接失败:".$conn->connect_error);}echo"连接成功!";?>说明:newmysqli():用于创建一个新的MySQL数据库连接。connect_error:如果连接失败,会返回错误信息。你可以根据需要替换$servername,$username,$password,和$dbname的值。扩展:查询数据示例query($sql);if($result->num_rows>0){while($row=$result->fetch_assoc()){echo"ID:".$row["id"]."-Name:".$row["name"]."
";}}else{echo"0结果";}?>如需使用预处理语》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>