提问人:Mohammad Sayeed 提问时间:2/16/2016 最后编辑:Mohammad Sayeed 更新时间:3/25/2021 访问量:478016
如何在 PHP 7 中启用 MySQLi 扩展?
How can I enable the MySQLi extension in PHP 7?
问:
我已经在 Ubuntu 7 (Trusty Tahr) 上安装了 PHP 7 和 MySQL 5.5.47 和 MySQL。
我已使用以下方法检查了已安装的扩展:
sudo apt-cache search php7-*
它输出:
php7.0-common - Common files for packages built from the PHP source
libapache2-mod-php7.0 - server-side, HTML-embedded scripting language (Apache 2 module)
php7.0-cgi - server-side, HTML-embedded scripting language (CGI binary)
php7.0-cli - command-line interpreter for the PHP scripting language
php7.0-phpdbg - server-side, HTML-embedded scripting language (PHPDBG binary)
php7.0-fpm - server-side, HTML-embedded scripting language (FPM-CGI binary)
libphp7.0-embed - HTML-embedded scripting language (Embedded SAPI library)
php7.0-dev - Files for PHP7.0 module development
php7.0-dbg - Debug symbols for PHP7.0
php7.0-curl - CURL module for PHP
php7.0-enchant - Enchant module for PHP
php7.0-gd - GD module for PHP
php7.0-gmp - GMP module for PHP
php7.0-imap - IMAP module for PHP
php7.0-interbase - Interbase module for PHP
php7.0-intl - Internationalisation module for PHP
php7.0-ldap - LDAP module for PHP
php7.0-mcrypt - libmcrypt module for PHP
php7.0-readline - readline module for PHP
php7.0-odbc - ODBC module for PHP
php7.0-pgsql - PostgreSQL module for PHP
php7.0-pspell - pspell module for PHP
php7.0-recode - recode module for PHP
php7.0-snmp - SNMP module for PHP
php7.0-tidy - tidy module for PHP
php7.0-xmlrpc - XMLRPC-EPI module for PHP
php7.0-xsl - XSL module for PHP
php7.0 - server-side, HTML-embedded scripting language (metapackage)
php7.0-json - JSON module for PHP
php-all-dev - package depending on all supported PHP development packages
php7.0-sybase - Sybase module for PHP
php7.0-sqlite3 - SQLite3 module for PHP
php7.0-mysql - MySQL module for PHP
php7.0-opcache - Zend OpCache module for PHP
php7.0-bz2 - bzip2 module for PHP
我也无法使用 phpinfo() 看到 MySQLi 扩展。如何在 PHP 7 中启用/安装 MySQLi 扩展?
这就是为什么我不能使用phpMyAdmin。它说“缺少mysqli扩展”。
答:
我得到了解决方案。我能够在php.ini启用MySQLi扩展。我刚刚在php.ini中取消了这一行的注释:
extension=php_mysqli.dll
现在MySQLi运行良好。以下是 Apache 2、PHP 7 和 Ubuntu 14.04 环境中的文件路径:php.ini
/etc/php/7.0/apache2/php.ini
默认情况下,MySQLi 扩展在 PHP 7 中被禁用。
评论
php_mysqli.dll
适用于 Windows。
extension_dir
ext/php_mysqli.dll
在 Ubuntu 中,您需要在位于 /etc/php/7.0/apache2/php.ini 的文件php.ini中取消注释此行:
extension=php_mysqli.so
评论
问题是用于将PHP连接到MySQL的软件包已弃用(php5-mysql)。如果安装新软件包,
sudo apt-get install php-mysql
这将自动更新 Apache 和 PHP 7。
评论
sudo service apache2 restart
apt-get install php7.3-mysqli
<?php phpinfo();?>
mysqli
apt install php-mysql
# sudo apt-get install -y php-mysqli Reading package lists... Done Building dependency tree Reading state information... Done Note, selecting 'php7.4-mysql' instead of 'php-mysqli' php7.4-mysql is already the newest version (7.4.3-4ubuntu2.10). 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
sudo phpenmod mysqli
sudo service apache2 restart
phpenmod moduleName
启用一个模块到 PHP 7(之后重新启动 Apachesudo service apache2 restart
)phpdismod moduleName
禁用 PHP 7 的模块(之后重新启动 Apachesudo service apache2 restart
)php -m
列出已加载的模块
评论
php-mysql
让我们使用
mysqli_connect
而不是
mysql_connect
因为在 PHP 7 中不受支持。mysql_connect
在 Ubuntu 上,当缺少 mysqli 时,执行以下命令:
sudo apt-get install php7.x-mysqli
sudo service apache2 restart
替换为您的 PHP 版本。7.x
注意:这可能是 7.0 及更高版本,但例如,Drupal 出于安全等原因推荐 PHP 7.2。
要检查您的 PHP 版本,请在命令行中键入:
php -v
如果缺少 mbstring,则执行完全相同的操作:
apt-get install php7.x-mbstring
service apache2 restart
我最近在 Ubuntu 7.0 (Xenial Xerus) 上将 PHP 从 7.0 升级到 7.04 时不得不为 phpMyAdmin 执行此操作。
评论
对于所有 docker 用户,只需从 php 容器内部运行即可。docker-php-ext-install mysqli
更新:有关 https://hub.docker.com/_/php 的更多信息,请参阅“如何安装更多PHP扩展”部分。
评论
如果是 docker,按照上面 Speedy 的答案安装 mysqli 后,您应该按照此答案重新启动 fpm https://stackoverflow.com/a/43076457/932473docker-php-ext-install mysqli
从容器内部
kill -USR2 1
评论