2005-05-22 23:24:09 +00:00
< ? PHP
//////////////////////////////////////////////////////////////////////////
// + $Id$
// +------------------------------------------------------------------+ //
// + Cake <https://developers.nextco.com/cake/> + //
// + Copyright: (c) 2005, Cake Authors/Developers + //
// + Author(s): Michal Tatarynowicz aka Pies <tatarynowicz@gmail.com> + //
// + Larry E. Masters aka PhpNut <nut@phpnut.com> + //
// + Kamil Dzielinski aka Brego <brego.dk@gmail.com> + //
// +------------------------------------------------------------------+ //
// + Licensed under The MIT License + //
// + Redistributions of files must retain the above copyright notice. + //
// + See: http://www.opensource.org/licenses/mit-license.php + //
//////////////////////////////////////////////////////////////////////////
/**
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
* PostgreSQL layer for DBO .
2005-05-22 23:24:09 +00:00
*
* @ filesource
* @ author Cake Authors / Developers
* @ copyright Copyright ( c ) 2005 , Cake Authors / Developers
* @ link https :// developers . nextco . com / cake / wiki / Authors Authors / Developers
* @ package cake
* @ subpackage cake . libs
* @ since Cake v 1.0 . 0.114
* @ version $Revision $
* @ modifiedby $LastChangedBy $
* @ lastmodified $Date $
* @ license http :// www . opensource . org / licenses / mit - license . php The MIT License
*/
/**
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
* Include DBO .
2005-05-22 23:24:09 +00:00
*/
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
uses ( 'dbo' );
2005-05-22 23:24:09 +00:00
/**
2005-06-02 19:37:06 +00:00
* PostgreSQL layer for DBO .
2005-05-22 23:24:09 +00:00
*
* @ package cake
* @ subpackage cake . libs
* @ since Cake v 1.0 . 0.114
*/
class DBO_Postgres extends DBO {
/**
2005-05-31 23:18:22 +00:00
* Connects to the database using options in the given configuration array .
2005-05-22 23:24:09 +00:00
*
2005-05-31 23:18:22 +00:00
* @ param array $config Configuration array for connecting
2005-06-11 03:45:31 +00:00
* @ return True if successfully connected .
2005-05-22 23:24:09 +00:00
*/
function connect ( $config ) {
if ( $config ) {
$this -> config = $config ;
$this -> _conn = pg_pconnect ( " host= { $config [ 'host' ] } dbname= { $config [ 'database' ] } user= { $config [ 'login' ] } password= { $config [ 'password' ] } " );
}
$this -> connected = $this -> _conn ? true : false ;
if ( $this -> connected )
return true ;
else
die ( 'Could not connect to DB.' );
}
/**
2005-05-31 23:18:22 +00:00
* Disconnects from database .
2005-05-22 23:24:09 +00:00
*
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
* @ return boolean True if the database could be disconnected , else false
2005-05-22 23:24:09 +00:00
*/
function disconnect () {
return pg_close ( $this -> _conn );
}
/**
2005-05-31 23:18:22 +00:00
* Executes given SQL statement .
2005-05-22 23:24:09 +00:00
*
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
* @ param string $sql SQL statement
* @ return resource Result resource identifier
2005-05-22 23:24:09 +00:00
*/
function execute ( $sql ) {
return pg_query ( $this -> _conn , $sql );
}
/**
2005-05-31 23:18:22 +00:00
* Returns a row from given resultset .
2005-05-22 23:24:09 +00:00
*
* @ param unknown_type $res
* @ return unknown
*/
function fetchRow ( $res ) {
return pg_fetch_array ( $res );
}
/**
2005-05-31 23:18:22 +00:00
* Returns an array of tables in the database . If there are no tables , an error is raised and the application exits .
2005-05-22 23:24:09 +00:00
*
2005-05-31 23:18:22 +00:00
* @ return array Array of tablenames in the database
2005-05-22 23:24:09 +00:00
*/
2005-06-11 03:45:31 +00:00
function tablesList () {
2005-05-22 23:24:09 +00:00
$sql = " SELECT a.relname AS name
FROM pg_class a , pg_user b
WHERE ( relkind = 'r' ) and relname !~ '^pg_' AND relname !~ '^sql_'
AND relname !~ '^xin[vx][0-9]+' AND b . usesysid = a . relowner
AND NOT ( EXISTS ( SELECT viewname FROM pg_views WHERE viewname = a . relname )); " ;
$result = $this -> all ( $sql );
if ( ! $result ) {
trigger_error ( ERROR_NO_TABLE_LIST , E_USER_ERROR );
exit ;
}
else {
$tables = array ();
foreach ( $result as $item ) $tables [] = $item [ 'name' ];
return $tables ;
}
}
/**
2005-05-31 23:18:22 +00:00
* Returns an array of the fields in given table name .
2005-05-22 23:24:09 +00:00
*
2005-05-31 23:18:22 +00:00
* @ param string $table_name Name of database table to inspect
* @ return array Fields in table . Keys are name and type
2005-05-22 23:24:09 +00:00
*/
function fields ( $table_name ) {
$sql = " SELECT c.relname, a.attname, t.typname FROM pg_class c, pg_attribute a, pg_type t WHERE c.relname = ' { $table_name } ' AND a.attnum > 0 AND a.attrelid = c.oid AND a.atttypid = t.oid " ;
$fields = false ;
foreach ( $this -> all ( $sql ) as $field ) {
$fields [] = array (
'name' => $field [ 'attname' ],
'type' => $field [ 'typname' ]);
}
return $fields ;
}
/**
2005-05-31 23:18:22 +00:00
* Returns a quoted and escaped string of $data for use in an SQL statement .
2005-05-22 23:24:09 +00:00
*
2005-05-31 23:18:22 +00:00
* @ param string $data String to be prepared for use in an SQL statement
* @ return string Quoted and escaped
2005-05-22 23:24:09 +00:00
*/
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
function prepareValue ( $data ) {
2005-05-29 19:43:59 +00:00
return " ' " . pg_escape_string ( $data ) . " ' " ;
2005-05-22 23:24:09 +00:00
}
/**
2005-05-31 23:18:22 +00:00
* Returns a formatted error message from previous database operation .
2005-05-22 23:24:09 +00:00
*
2005-05-31 23:18:22 +00:00
* @ return string Error message
2005-05-22 23:24:09 +00:00
*/
function lastError () {
return pg_last_error () ? pg_last_error () : null ;
}
/**
2005-05-31 23:18:22 +00:00
* Returns number of affected rows in previous database operation . If no previous operation exists , this returns false .
2005-05-22 23:24:09 +00:00
*
2005-05-31 23:18:22 +00:00
* @ return int Number of affected rows
2005-05-22 23:24:09 +00:00
*/
function lastAffected () {
return $this -> _result ? pg_affected_rows ( $this -> _result ) : false ;
}
/**
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
* Returns number of rows in previous resultset . If no previous resultset exists ,
* this returns false .
2005-05-22 23:24:09 +00:00
*
I've merged in Olle's changes.
Larry, I've merged in _some_ of your changes, I'll merge in the scaffolding and joins code when you tell me it's ready. But I don't want to break how the Controller class works, can't we really do without the constructClasses() method call? Which reminds me, with your joins code, will we be able to use constructs like $user->post->findAll() and $user->post->save()?
Also, what are your changes to the DBO_MySQL class? I mean the mysqlResultSet(), and fetchResult() methods. I didn't see any MySQL-specific code inside them, perhaps they belong to the DBO class itself?
- I've changed the headers on user-editable files in /app and /config. I hope they will constitute a compromise between readability and legality. I've left file Id, copyright, and licence notices.
- /libs/basic.php::uses() function logs included files in global $loaded. Please, consider it a note to myself. Also, I've moved the NeatArray class out of the /libs/basics.php (into /libs/neat_array.php).
- Some cleanups in the Controller and Dispatcher classes.
- DBO::Prepare() accepts strings _and_ arrays now. It's a step towards a unified params theory.
- I think I've added some comments to DBO sub-classes, but it might have been Olle.
- A fix in Model class (findAll didn't work properly)
- Object's constructor sets $this->db to &DBO, which means all Object-descendand classes have default access to the database if it's connected. We need to clean up the code accordingly (some classes set their own $this->db references).
git-svn-id: https://svn.cakephp.org/repo/trunk/cake@236 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-06-05 11:05:24 +00:00
* @ return int Number of rows
2005-05-22 23:24:09 +00:00
*/
function lastNumRows () {
return $this -> _result ? pg_num_rows ( $this -> _result ) : false ;
}
/**
2005-05-31 23:18:22 +00:00
* Returns the ID generated from the previous INSERT operation .
2005-05-22 23:24:09 +00:00
*
2005-05-31 23:18:22 +00:00
* @ param string $table Name of the database table
* @ param string $field Name of the ID database field . Defaults to " id "
2005-05-22 23:24:09 +00:00
* @ return unknown
*/
function lastInsertId ( $table , $field = 'id' ) {
$sql = " SELECT CURRVAL(' { $table } _ { $field } _seq') AS max " ;
$res = $this -> rawQuery ( $sql );
$data = $this -> fetchRow ( $res );
return $data [ 'max' ];
}
}
2005-05-16 23:14:37 +00:00
?>