连接postgresql和codeigniter

时间:2015-04-14 15:04:07

标签: php database postgresql codeigniter

我是使用postgresql的新手,我已经使用Codeigniter一年了。

我有一个小的postgresql数据库,我想从Codeigniter调用它。

在我的database.php文件中,我有这样的设置:

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

$db['default'] = array(
'dsn'   => 'pgsql:host=localhost;port=5432;dbname=test;user=postgres;password=aPass',
// 'dsn'    => '',
'hostname' => 'localhost',
'username' => 'postgres',
'password' => 'aPass',
'database' => 'test',
'dbdriver' => '',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => TRUE,
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
  // 'port' => '5432'
);

在控制器中我有这个功能:

public function dbtest(){

    $this->load->database();

    $feeds = $this->db->get('vts_feeds');
    echo $feeds;die();
}

我得到的结果是:

An Error Was Encountered
You have not selected a database type to connect to.

为什么不起作用?

6 个答案:

答案 0 :(得分:8)

尝试设置,

  

dbdriver - 数据库类型。即:mysql,postgres,odbc等必须   以小写字母指定。

更多信息:https://www.codeigniter.com/user_guide/database/configuration.html

编辑:在postgres中为PDO试用此配置

$db['default']['hostname'] = 'pgsql:host=localhost;dbname=yourdb'; //set host
$db['default']['username'] = 'your username'; //set username
$db['default']['password'] = 'your password'; //set password
$db['default']['database'] = 'your database'; //set databse
$db['default']['dbdriver'] = 'pdo'; //set driver here

答案 1 :(得分:3)

删除'dsn'字符串并更改为配置数组中的'dbdriver' => 'postgre'

尽管CI文档声明值应为'postgres',但如果您检查system>database>drivers中的目录和文件名,则该文件夹实际上称为'postgre',文件名为'postgre_driver.php'和班级'CI_DB_postgre_driver'所以我们可以假设这里的文档是错误的。奇怪的是,这并没有在

之前提升它的丑陋头脑

答案 2 :(得分:1)

在文件database.php中,内容为:

'dbdriver' => ' ',

提出以下论点:

'dbdriver' => 'pgsql',

答案 3 :(得分:1)

我现在就做了。 你刚离开:

$db['default']['dsn'] = '';

并设置:

$db['default']['dbdriver'] = 'postgre';

答案 4 :(得分:0)

我遇到了同样的问题。请尝试以下步骤

  1. 不要删除dsn字符串添加port=>5432到您的配置数组
  2. 将dbdriver设置为'dbdriver' => 'postgres'
  3. 如果启用了postgre扩展名,请检查您的php.ini文件extension=php_pdo_pgsql.dll

答案 5 :(得分:-1)

为什么不通过使用 linux 终端在 psql 中创建一个用户,然后授予该用户的所有访问权限?然后用那个更改配置数据库中的用户名和密码。