如何在Codeigniter 3中连接到POSTGRESQL?

Raj*_*jan 8 php postgresql tcp codeigniter

我正在尝试使用Codeigniter框架连接到PostgreSQL.现在在我的database.php中

我有以下代码:

$active_group = 'default';
$query_builder = TRUE;

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'localhost',
    'username' => 'postgres',
    'password' => '',
    'database' => 'fmsdb',
    'dbdriver' => 'postgre',
    'dbprefix' => '',
    'pconnect' => FALSE,
    'db_debug' => (ENVIRONMENT !== 'production'),
    'cache_on' => FALSE,
    'cachedir' => '',
    'char_set' => 'utf8',
    'dbcollat' => 'utf8_general_ci',
    'swap_pre' => '',
    'encrypt' => FALSE,
    'compress' => FALSE,
    'stricton' => FALSE,
    'failover' => array(),
    'save_queries' => TRUE
);
Run Code Online (Sandbox Code Playgroud)

但是当我在localhost中运行我的站点时,我得到以下数据库错误:

遇到PHP错误

严重性:警告

消息:pg_connect():无法连接到PostgreSQL服务器:无法连接到服务器:权限被拒绝服务器是否在主机"localhost"(:: 1)上运行并接受端口5432上的TCP/IP连接?无法连接到服务器:权限被拒绝服务器是否在主机"localhost"(127.0.0.1)上运行并接受端口5432上的TCP/IP连接?

文件名:postgre/postgre_driver.php

行号:154

我尝试将它放在我的PostgreSQL.conf文件中:

listen_addresses = '*'
Run Code Online (Sandbox Code Playgroud)

我哪里错了?

Abd*_*lam 6

首先启用Postgresql扩展php.ini

extension=php_pgsql.dll

您也可以Postgresql为PDO 启用扩展.

extension=php_pdo_pgsql.dll


$db['default'] = array(
    'port'   => 5432, # Add 
);
Run Code Online (Sandbox Code Playgroud)

要么

$db['default'] = array(
    'dsn'   => 'pgsql:host=localhost;port=5432;dbname=database_name', 
    'dbdriver' => 'pdo',
);
Run Code Online (Sandbox Code Playgroud)

codeigniter.com中的数据库配置