PHP pdo异常“找不到驱动程序”pgsql

时间:2013-11-07 13:41:26

标签: php postgresql exception pdo driver

所以当我尝试在Mapper类的构造函数中创建数据库时,我总是得到一个pdo异常。 在这一行:

$this->db = new PDO($dsn, $db_config['username'], $db_config['password']);

这是我的dsn创作:

    $db_config = array(
    'driver' => 'pgsql',
    'username' => $dbUser,
    'password' => $dbPassword,
    'schema' => 'r0628740',
    'dsn' => array(
        'host' => 'gegevensbanken.khleuven.be',
        'dbname' => '2TX31',
        'port' => '51314',
    )
);

最后我的构造函数:

public function __construct(){
        global $db_config;
        $dsn = $db_config['driver'] . ':';
        foreach($db_config['dsn'] as $key => $value){
            $dsn .= $key . '=' . $value . ';';
        }
        try{

            $this->db = new PDO($dsn, $db_config['username'], $db_config['password']);
            $this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

            if(($db_config['driver'] == 'pgsql') && isset($db_config['schema'])){
                $this->db->query(sprintf("SET SEARCH_PATH TO %s"), $db_config['schema']);
            }
        }catch (PDOException $e){
            var_dump($e->getLine());
            error_log($e->getMessage());
        }

    }

3 个答案:

答案 0 :(得分:2)

PHP包含pgsql和pgsql_pdo驱动程序libpq.dll所需的dll ... 将PHP二进制路径添加到系统路径或将de DLL复制到Windows \ system32。在linux上依赖是自动安装的。

答案 1 :(得分:0)

我在某个地方找到了文章,对我有用。假设您已安装PostgreSQL且您的WAMP安装在c:\wamp,则需要复制:

c:\wamp\bin\php\php5.3.9\libpq.dllc:\wamp\bin\apache\Apache2.2.11\bin

确保您还拥有以下文件:

C:\wamp\bin\php\php5.3.9\ext\php_pdo_pgsql.dllC:\wamp\bin\php\php5.3.9\ext\php_pgsql.dll

此外,请确保您已通过WAMP菜单启用上述2个文件作为扩展名(点击任务栏上的WAMP图标:PHP > PHP extensions,找到上述2并检查'他们)。

请注意php5.3.9Apache2.2.11是指我的特定PHP和Apache版本。

根据您的安装进行调整。

答案 2 :(得分:0)

将此 libpq.dll c:\ wamp \ bin \ php \ php5.3.9 \ libpq.dll 复制到 c:\ wamp \ bin \ apache \ Apache2.2.11 \ bin 。为我工作