0

0

怎么配置PHP数据库连接_PHP连接MySQL的设置【方法】

星夢妙者

星夢妙者

发布时间:2026-02-17 14:19:34

|

766人浏览过

|

来源于php中文网

原创

php连接mysql失败需依次检查:一、启用mysqli或pdo扩展并重启服务器;二、用mysqli面向过程/对象方式或pdo连接,注意参数与错误处理;三、验证mysql服务、用户权限及bind-address配置。

怎么配置php数据库连接_php连接mysql的设置【方法】

如果您在开发PHP应用程序时需要与MySQL数据库进行交互,但无法成功建立连接,则可能是由于数据库连接参数配置错误或扩展未启用。以下是配置PHP数据库连接的具体方法:

一、检查并启用MySQLi或PDO扩展

PHP默认不自动启用MySQL相关扩展,必须确保php.ini中已加载MySQLi或PDO MySQL扩展,否则调用连接函数会报错。

1、打开PHP安装目录下的php.ini文件。

2、查找extension=mysqliextension=pdo_mysql两行,确认其前面没有分号(;)注释符。

立即学习PHP免费学习笔记(深入)”;

3、若被注释,删除每行开头的分号。

4、保存php.ini文件后,重启Web服务器(如Apache或Nginx)使配置生效。

5、创建一个PHP文件,写入<?php phpinfo(); ?>并访问,搜索“mysqli”和“pdo_mysql”,确认模块已加载。

二、使用MySQLi面向过程方式连接

MySQLi扩展提供面向过程和面向对象两种接口,面向过程方式适合简单脚本,通过函数直接传入连接参数完成初始化。

1、定义数据库主机、用户名、密码、数据库名变量,例如:$host = "localhost"; $user = "root"; $pass = ""; $db = "test";

2、调用mysqli_connect()函数,传入四个参数:$conn = mysqli_connect($host, $user, $pass, $db);

3、使用mysqli_connect_error()检测是否连接失败,如返回非空字符串则说明连接异常。

4、若连接成功,可执行查询语句,例如:mysqli_query($conn, "SELECT * FROM users");

5、操作完成后调用mysqli_close($conn)关闭连接。

三、使用MySQLi面向对象方式连接

面向对象方式将连接封装为MySQLi类实例,支持更清晰的错误处理和链式调用,适用于结构化项目。

1、使用new mysqli()构造函数,按顺序传入主机、用户名、密码、数据库名和端口(端口可选,默认3306)。

简灰服装商城整站 For SHOPEX
简灰服装商城整站 For SHOPEX

SHOPEX简灰服装商城整站源码下载。 安装方法:1.解压上传程序至网站根目录.. 访问:域名/bak.(用户名:admin 密码:123456)2.进入帝国备份王后,配置数据库数据库信息.选择-www.taomoban.net目录.还原数据库.3.修改FTP目录下的config/config.phpphp 数据库连接信息.4.登陆网站后台--清空缓存..5.删除bak文件夹 后台:shopadm

下载

2、示例:$mysqli = new mysqli("localhost", "root", "", "test");

3、检查$mysqli->connect_error属性是否为null,若不为null则表示连接失败。

4、成功后可通过$mysqli->query()执行SQL语句,如:$mysqli->query("INSERT INTO logs (msg) VALUES ('init')");

5、连接不再需要时,调用$mysqli->close()释放资源。

四、使用PDO方式连接MySQL

PDO是PHP数据对象接口,支持多种数据库驱动,具有预处理语句和异常模式等高级特性,适合需要数据库移植性的应用。

1、构造DSN(数据源名称),格式为"mysql:host=localhost;dbname=test;charset=utf8mb4",注意指定字符集避免乱码。

2、调用PDO构造函数,传入DSN、用户名、密码及可选选项数组,例如:$pdo = new PDO($dsn, $user, $pass, [PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]);

3、设置PDO::ATTR_ERRMODEPDO::ERRMODE_EXCEPTION可让错误抛出异常,便于捕获处理。

4、使用$pdo->prepare()$pdo->execute()执行带参数的SQL,防止SQL注入。

5、PDO连接在对象销毁时自动关闭,也可显式调用$pdo = null释放引用。

五、验证连接参数与权限配置

即使PHP扩展启用且代码语法正确,仍可能因MySQL服务状态或用户权限问题导致连接拒绝,需单独排查服务端配置。

1、确认MySQL服务正在运行,Linux下执行systemctl status mysqld,Windows下检查服务列表中MySQL是否启动。

2、登录MySQL命令行,执行SELECT User, Host FROM mysql.user;查看用户授权范围,特别注意Host字段是否允许从PHP所在主机(如%或具体IP)连接

3、若用户Host为localhost,则仅接受Unix socket或127.0.0.1本地回环连接;远程连接需对应Host设为%或目标IP

4、执行GRANT ALL PRIVILEGES ON test.* TO 'root'@'%' IDENTIFIED BY 'password'; FLUSH PRIVILEGES;授予必要权限。

5、检查MySQL配置文件my.cnf中bind-address是否限制为127.0.0.1,如需远程访问应改为0.0.0.0或注释该行。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

965

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

376

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1696

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

370

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1252

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

436

2024.04.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.3万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 834人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号