当前位置: 首页 > 面试题库 >

PHP 7.0上的Laravel 5.4:PDO异常-找不到驱动程序(MySQL)

萧德庸
2023-03-14
问题内容

我在Ubuntu 14.04(带有Plesk 12.5.30的VPS)上有一个Laravel 5.4项目。创建数据库并使用所需信息设置 .env
文件后,我运行了php artisan migrate并且引发了异常:

[Illuminate \ Database \ QueryException]
找不到驱动程序(SQL:从information_schema.tables中选择*,其中table_schema =
pmaramaldb,table_name =迁移)

[PDOException]
找不到驱动程序

我的 .env 文件包含:

DB_CONNECTION = mysql

DB_HOST = 127.0.0.1

DB_PORT = 3306

DB_DATABASE = pmaramaldb

DB_USERNAME =用户

DB_PASSWORD =密码

我遵循了大多数指南来解决此错误,但是没有任何积极的结果:

启用扩展解决方案:

已启用PDO

php.ini中 被自动生成的文件,我想这是做的Plesk。在文件的开头,它说:

; 注意!
;
; 请勿修改此文件,因为它是自动生成的
;因此,下次生成文件时,所有更改都将丢失。

所以无论如何我都尝试过。之后,我重新启动了Apache,然后再试一次。

安装php7.0-mysql解决方案:

我还尝试安装MySQL,以防万一不是:

user @ server:/ var / www / vhosts $ sudo apt-get install php7.0-mysql

Leyendo lista de paquetes …

Creandoárboldedependencias

…更多信息

php7.0-mysql已经是最新版本。

0个实际结果,0个实际安装情况,0个等级和67个没有实际结果。

SQL Lite安装解决方案:

我还尝试过问题链接说:sudo apt-get install php5-sqlite结果是:

user @ server:/var/www/vhosts/system/maramal.io/etc$ sudo apt-get install
php5-sqlite

Leyendo lista de paquetes …

Creandoárboldedependencias

…更多信息

php5-sqlite已经是最新版本。

0个实际结果,0个实际安装情况,0个等级和67个没有实际结果。

Composer转储-自动加载解决方案:

它也不起作用。我已经尝试过了composer dump-autoload,但是没有用。

运行命令后php -i

PDO

PDO支持=>启用

PDO驱动程序=>

PHP版本=> 5.6.30-1 + deb.sury.org〜trusty + 1

好吧,我不确定这是否与错误有关,但是运行显示的版本php -v是:

用户@服务器:〜/ path $ php -v

PHP 5.6.30-1 + deb.sury.org〜trusty + 1(CLI)

版权所有(c)1997-2016 The PHP Group

Zend Engine v2.6.0,版权所有(c)1998-2016,
具有Zend OPcache v7.0.6-dev的Zend Technologies,由Zend
Technologies版权所有(c)1999-2016


问题答案:

Apache使用的PHP与链接到命令行的PHP之间存在冲突。(这种情况经常发生,应该说实话)。

通常要做的是:

which php

这告诉您在命令行中运行时将使用哪个php。例如/usr/bin/php

mv /usr/bin/php /usr/bin/php.old

然后将正确的PHP版本链接或复制到可执行路径:

ln -s /path/to/php/bin/php /usr/bin/php

或以下内容也应该起作用。

cp /path/to/php/bin/php /usr/bin/php

如果您希望能够手动安装mod,也建议:

ln -s /path/to/php/bin/phpize /usr/bin/phpize
ln -s /path/to/php/bin/php-config /usr/bin/php-config

这样,您的CLI将与您的Web服务器匹配。

更新:

如果如本答案所述,如果您将Ubuntu与PHP的多个备用安装一起使用,则可以执行以下操作:

sudo update-alternatives --set php /usr/bin/php<version>
sudo update-alternatives --set phar /usr/bin/phar<version>
sudo update-alternatives --set phar.phar /usr/bin/phar.phar<version> 
sudo update-alternatives --set phpize /usr/bin/phpize<version> 
sudo update-alternatives --set php-config /usr/bin/php-config<version>


 类似资料:
  • 我在我的Ubuntu14.04上有一个Laravel5.4项目(带有Plesk12.5.30的VPS)。创建数据库并使用所需信息设置.env文件后,我运行了,并引发异常: 无法找到驱动程序(SQL:选择*frominformation_schema.tables其中table_schema=pmaramaldb和table_name=迁移) [PDO异常] 找不到驱动程序 My.env文件具有:

  • 问题内容: 我在安装laravel时遇到了不好的经验。但是,我能够这样做,并进入了新的高度。我使用生成器并创建了迁移。但是当我键入最后一条命令时 它引发PDOException-找不到驱动程序。 那是我在config / database.php中的配置。 我尝试在stackoverflow和laravel论坛上进行搜索,人们认为这是PDO问题,而不是artisan或php的问题-我遵循这些建议,

  • 如果我使用的是maven插件,并且通过它一切都很好,但是我怎么能在没有Maven插件的情况下运行它,使用运行配置并从那里设置Tomcat。如果我做一些,出现以下错误: 使用插件一切工作:Maven项目 - 但是,当我尝试通过不同的运行配置运行同一个项目时,问题出现了,如下所示: 错误来自标记行: 问题可能与运行配置有关。

  • 我有selenium 2.53.1.jar、platform Windows、Java-1.8、chrome=52.0、chrome-driver.exe-2.23。 在Jenkins上进行夜间观察测试时,我看到了以下消息。 org.openqa.selenium.WebDriverException:未知错误:无法发现打开的页面(驱动信息:chromeDrive=2.23.409699 (49b

  • 问题内容: 嗨,我收到尝试通过php文件连接到sqlite时 找不到驱动程序 错误的消息。我已将权限设置为777 … PHP 5.2.16版,已安装模块。任何找不到驱动程序的原因,php.ini都显示了已安装的扩展名pdo.so和pdo_mysql.so。 PDO 已启用PDO支持的PDO驱动程序mysql pdo_mysql 适用于MySQL的PDO驱动程序,客户端库版本5.0.92 问题答案:

  • 问题内容: 输出 >无法连接到数据库服务器java.lang.ClassNotFoundException 问题答案: 看来您应该将MySQL驱动程序jar放入 类路径中 。