一、分析工作 :
你报错的根本原因:由于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服务器!!!