PHP链接Mysql数据库出问题解决方案

一、分析工作 :

你报错的根本原因:由于MySQL扩展从php 5.5开始弃用,所以以后不推荐大家再用MySQL扩展,请用MySQLi或PDO代替。

​PHP 5 及以上版本建议使用以下方式连接 MySQL :

  • MySQLi extension ("i" 意为 improved)
  • PDO (PHP Data Objects)

我是该用 MySQLi ,还是 PDO?

如果你需要一个简短的回答,即 "你习惯哪个就用哪个"。

MySQLi 和 PDO 有它们自己的优势:

PDO 应用在 12 种不同数据库中, MySQLi 只针对 MySQL 数据库。

二、本文章用实例 (MySQLi - 面向过程)链接数据库,代码如下:

<?php
$servername = "localhost";
$username = "root";
$password = "root";
 
// 创建连接
$conn = mysqli_connect($servername, $username, $password);
 
// 检测连接
if (!$conn) {
    die("Connection failed: " . mysqli_connect_error());
}
echo "连接成功";
?>

现实很残酷!!

错误信息Fatal error: Uncaught Error: Class "mysqli"not found in D:(veb\apacheApache24\htdocs\index.php:7 Stacktrace: #0 {main} thrown in D:\veblapache\Apache24\htdocs\index.php on line 7

 三、解决方案

网上有配置环境变量来解决的方法,没有任何作用!!

第一步:

在php.ini中找到;extension_dir = "ext",更改为php目录下的ext文件夹的路径

extension_dir = "E:\web\php8.0\ext"

 

 特别提醒:去掉extension_dir的";"

第二步:

开启curl扩展,找到:;extension=curl,去掉分号;

extension=curl

第三步:

去掉部分注释;

extension=bz2
extension=curl
extension=fileinfo
extension=gd
extension=gettext
extension=mbstring
extension=mysqli
extension=openssl
extension=pdo_mysql
extension=soap
extension=sockets
extension=sqlite3
extension=tidy
extension=xmlrpc
extension=xsl

第四步:

添加自定义扩展,放在文件末尾即可。

;[memcache]
extension=php_memcache.dll
;[redis]
extension=php_redis.dll

 最后还是用PHP中输入print phpinfo();

在显示的信息中找到mysqli模块,说明加载成功

 再次运行链接代码

 大功告成,又秃头了!

特别提示:mysql_connect()等类似函数要改为mysqli_connect()

最后重新启动Apache服务器!!!

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值