CakePHPでPostgreSQLを使う場合のdatabase.phpはこういう感じ。
var $default = array(
'datasource' => 'Database/Postgres',
'persistent' => 'false',
'host' => 'localhost',
'port' => '5432',
'login' => 'user_name',
'password' => 'password',
'database' => 'test_db',
'schema' => 'public',
'prefix' => '',
'encoding' => 'utf8'
);
MySQLの場合チュートリアル通りにやれば問題無いが、
PostgreSQLではportとschemaを指定しないと以下のようなエラーになる。
Error: Table posts for model Post was not found in datasource default.
また、Windowsのローカルで開発を行う場合、PostgreSQLにつなぐためのDLLが必要になる。
設定はできているのに繋がらない。もしくは、ピュアなPHPプログラムからはPostgreSQLに接続できるのに、CakePHPからは接続出来ない場合は、以下のDLLが壊れていないか確認すること。
Error: Database connection "Postgres" is missing, or could not be created.
- php_pdo_pgsql.dll
- php_pgsql.dll