php - Symfony 3 MySQL 驱动程序 'could not find driver'

标签 php mysql symfony pdo doctrine-orm

实际上我在使用 Symfony 3 和 PDO 驱动程序时遇到了一些困难。

这是我使用 Symfony 3 的第一个项目(之前我使用 Symfony 2),当我想使用 Doctrine 或 FOSUserBundle 时,我得到了这个错误:

could not find driver

500 Internal Server Error - PDOException

我检查出了什么问题,我发现这是一个错误抛出: /path-to-project/vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOMySql

当 PDO 类无法访问数据库服务器时,这是一个简单的 PDOException 抛出。 但是 我可以毫无问题地执行这段代码 带有“$> php test.php”

$pdo = new PDO("mysql:dbname=Accounting;host=127.0.0.1","<user>", "<secret>");
$sql = 'SELECT * FROM Accounting.fos_user;';
echo count($pdo->query($sql));

这个错误是由相同的代码抛出的,由 Symfony 3 执行(通过 Doctrine 并在一个简单的 Controller 中测试)。


这是我的参数:

# app/config/parameters.yml
parameters:
    database_driver: pdo_mysql
    database_host: 127.0.0.1
    database_port: 3306
    database_name: Accounting
    database_user: <user>
    database_password: <secret>

# app/config/config.yml
# Doctrine Configuration
doctrine:
    dbal:
        driver:   "%database_driver%"
        host:     "%database_host%"
        port:     "%database_port%"
        dbname:   "%database_name%"
        user:     "%database_user%"
        password: "%database_password%"
        charset:  UTF8
        # if using pdo_sqlite as your database driver:
        #   1. add the path in parameters.yml
        #     e.g. database_path: "%kernel.root_dir%/data/data.db3"
        #   2. Uncomment database_path in parameters.yml.dist
        #   3. Uncomment next line:
        #     path:     "%database_path%"

    orm:
        auto_generate_proxy_classes: "%kernel.debug%"
        naming_strategy: doctrine.orm.naming_strategy.underscore
        auto_mapping: true
fos_user:
    db_driver: orm # other valid values are 'mongodb', 'couchdb' and 'propel'
    firewall_name: main
    user_class: UserBundle\Entity\User

编辑 29/03/2016

操作系统配置:虚拟机上的 Ubuntu 14-04

最佳答案

我会回答我自己的问题。发生此问题是因为我尝试在容器(形成虚拟化)上将 symfony 与 mysql pdo 驱动程序一起使用。当我在 真实 VM(= 完全虚拟化虚拟机)上使用相同的设置时,它工作正常。找到驱动程序,我们可以在 Symfony 3 项目中创建 pdo。

测试了 10/04/2016

Ty malcolm 的帮助,感谢你让我学到了一些东西:)

问候,Dykoine

关于php - Symfony 3 MySQL 驱动程序 'could not find driver',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36247203/

相关文章:

php - Doctrine2 中的实体 namespace 和别名是什么?

php - 哪种性能更好 - 使用 php-qt 或使用 swig 为 c++ 编写自定义 php 扩展?

unit-testing - Symfony2 - 使用 FOSUserBundle 进行测试

php - 带有 Symfony 和 PHP-FPM 的 NGINX SSI

javascript - 可选择的表行无法通过 jQuery AJAX 将 id 值发送到 PHP

PHP用户名密码解决方案

ADD 附近的 SQL 语法错误

javascript - 返回 HTML 时,存储在 MySQL 中的 Facebook 个人资料链接不起作用

mysql - 在 MySQL 中存储时间序列的最佳方式是什么?

mysql - Doctrine 不会使用 GROUP BY 自动加载连接关系