2007-01-07 14:52:16 +00:00
< ? php
/*
* $Id $
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT , INDIRECT , INCIDENTAL ,
* SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT NOT
* LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL . For more information , see
2008-01-22 22:52:53 +00:00
* < http :// www . phpdoctrine . org >.
2007-01-07 14:52:16 +00:00
*/
2008-05-06 13:41:22 +00:00
2008-05-30 12:09:24 +00:00
#namespace Doctrine::DBAL::Connections;
2007-01-07 14:52:16 +00:00
/**
* Doctrine_Connection
*
2007-05-27 18:56:04 +00:00
* A wrapper layer on top of PDO / Doctrine_Adapter
*
* Doctrine_Connection is the heart of any Doctrine based application .
*
* 1. Event listeners
* An easy to use , pluggable eventlistener architecture . Aspects such as
* logging , query profiling and caching can be easily implemented through
* the use of these listeners
*
* 2. Lazy - connecting
* Creating an instance of Doctrine_Connection does not connect
* to database . Connecting to database is only invoked when actually needed
2008-01-29 09:59:37 +00:00
* ( for example when query () is being called )
2007-05-27 18:56:04 +00:00
*
* 3. Convenience methods
2007-06-14 21:50:12 +00:00
* Doctrine_Connection provides many convenience methods such as fetchAll (), fetchOne () etc .
2007-05-27 18:56:04 +00:00
*
* 4. Modular structure
* Higher level functionality such as schema importing , exporting , sequence handling etc .
2008-01-29 09:59:37 +00:00
* is divided into modules . For a full list of connection modules see
2007-05-27 18:56:04 +00:00
* Doctrine_Connection :: $_modules
*
2007-01-07 14:52:16 +00:00
* @ package Doctrine
2007-10-03 21:43:22 +00:00
* @ subpackage Connection
2007-01-07 14:52:16 +00:00
* @ license http :// www . opensource . org / licenses / lgpl - license . php LGPL
2008-02-22 18:11:35 +00:00
* @ link www . phpdoctrine . org
2007-01-07 14:52:16 +00:00
* @ since 1.0
* @ version $Revision $
* @ author Konsta Vesterinen < kvesteri @ cc . hut . fi >
* @ author Lukas Smith < smith @ pooteeweet . org > ( MDB2 library )
2008-02-13 10:53:07 +00:00
* @ author Roman Borschel < roman @ code - factory . org >
2008-06-05 19:01:58 +00:00
* @ todo
* 1 ) REPLICATION SUPPORT
* Replication support should be tackled at this layer ( DBAL ) .
* There can be options that look like :
* 'slaves' => array (
* 'slave1' => array (
* user , pass etc .
* ),
* 'slave2' => array (
* user , pass etc .
* )),
* 'slaveConnectionResolver' => new MySlaveConnectionResolver (),
* 'masters' => array ( ... ),
* 'masterConnectionResolver' => new MyMasterConnectionResolver ()
*
* Doctrine :: DBAL could ship with a simple standard resolver that uses a primitive
* round - robin approach to distribution . User can provide its own resolvers .
2007-01-07 14:52:16 +00:00
*/
2008-06-15 15:56:28 +00:00
abstract class Doctrine_Connection implements Countable
2007-01-07 14:52:16 +00:00
{
/**
2008-02-03 21:29:57 +00:00
* The PDO database handle .
*
2008-07-04 16:32:19 +00:00
* @ var PDO
2007-01-07 14:52:16 +00:00
*/
2008-07-04 16:32:19 +00:00
protected $_pdo ;
2008-05-06 13:41:22 +00:00
2008-06-05 19:01:58 +00:00
/**
* The Configuration .
*
* @ var Configuration
*/
protected $_config ;
/**
* The EventManager .
*
* @ var EventManager
*/
protected $_eventManager ;
2008-05-30 12:09:24 +00:00
/**
* The attributes .
*
* @ var array
*/
protected $_attributes = array ();
2008-01-22 21:42:17 +00:00
/**
* Name of the connection
*
* @ var string $_name
*/
protected $_name ;
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-02-03 21:29:57 +00:00
* The name of this connection driver .
*
* @ var string $driverName
2007-01-07 14:52:16 +00:00
*/
2008-07-04 16:32:19 +00:00
protected $_driverName ;
2008-05-06 13:41:22 +00:00
2007-06-12 19:39:03 +00:00
/**
2008-02-03 21:29:57 +00:00
* Whether or not a connection has been established .
*
* @ var boolean $isConnected
2007-06-12 19:39:03 +00:00
*/
2008-07-04 16:32:19 +00:00
protected $_isConnected = false ;
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-02-03 21:29:57 +00:00
* An array containing all features this driver supports , keys representing feature
* names and values as one of the following ( true , false , 'emulated' ) .
*
* @ var array $supported
2007-01-07 14:52:16 +00:00
*/
2008-05-06 13:41:22 +00:00
protected $supported = array ();
/**
2008-05-17 12:22:24 +00:00
* The connection properties .
*
* @ var array $properties
2008-05-06 13:41:22 +00:00
*/
protected $properties = array (
2008-07-20 20:13:24 +00:00
'sql_comments' => array (
array ( 'start' => '--' , 'end' => " \n " , 'escape' => false ),
array ( 'start' => '/*' , 'end' => '*/' , 'escape' => false )),
2008-05-06 13:41:22 +00:00
'identifier_quoting' => array ( 'start' => '"' , 'end' => '"' , 'escape' => '"' ),
'string_quoting' => array ( 'start' => " ' " , 'end' => " ' " , 'escape' => false ,
'escape_pattern' => false ),
'wildcards' => array ( '%' , '_' ),
'varchar_max_length' => 255 ,
);
/**
* @ var array $serverInfo
*/
protected $serverInfo = array ();
/**
2008-06-05 19:01:58 +00:00
* The parameters used during creation of the Connection .
2008-07-20 20:13:24 +00:00
*
* @ var array
2008-05-06 13:41:22 +00:00
*/
2008-06-05 19:01:58 +00:00
protected $_params = array ();
2008-05-06 13:41:22 +00:00
/**
* List of all available drivers .
*
* @ var array $availableDrivers
*/
2008-07-04 16:32:19 +00:00
private static $_availableDrivers = array (
2008-05-06 13:41:22 +00:00
'Mysql' , 'Pgsql' , 'Oracle' , 'Informix' , 'Mssql' , 'Sqlite' , 'Firebird'
);
/**
* The query count . Represents the number of executed database queries by the connection .
*
* @ var integer
*/
2008-07-04 16:32:19 +00:00
protected $_queryCount = 0 ;
2007-10-21 06:23:59 +00:00
2008-05-06 13:41:22 +00:00
/*
* ----------- Mixed attributes ( need to split up ) ---------------
*/
2007-01-07 14:52:16 +00:00
/**
* @ var array $modules an array containing all modules
* transaction Doctrine_Transaction driver , handles savepoint and transaction isolation abstraction
*
* expression Doctrine_Expression driver , handles expression abstraction
*
* dataDict Doctrine_DataDict driver , handles datatype abstraction
*
* export Doctrine_Export driver , handles db structure modification abstraction ( contains
* methods such as alterTable , createConstraint etc . )
2007-08-16 21:54:14 +00:00
* import Doctrine_Import driver , handles db schema reading
2007-01-08 00:13:41 +00:00
*
* sequence Doctrine_Sequence driver , handles sequential id generation and retrieval
2007-01-07 14:52:16 +00:00
*
2007-05-27 18:56:04 +00:00
* unitOfWork Doctrine_Connection_UnitOfWork handles many orm functionalities such as object
* deletion and saving
*
* formatter Doctrine_Formatter handles data formatting , quoting and escaping
*
2007-01-07 14:52:16 +00:00
* @ see Doctrine_Connection :: __get ()
* @ see Doctrine_DataDict
* @ see Doctrine_Expression
* @ see Doctrine_Export
* @ see Doctrine_Transaction
2007-01-08 00:13:41 +00:00
* @ see Doctrine_Sequence
2007-05-27 18:56:04 +00:00
* @ see Doctrine_Connection_UnitOfWork
* @ see Doctrine_Formatter
2007-01-07 14:52:16 +00:00
*/
private $modules = array ( 'transaction' => false ,
'expression' => false ,
'dataDict' => false ,
'export' => false ,
2007-08-16 21:54:14 +00:00
'import' => false ,
2007-01-08 00:13:41 +00:00
'sequence' => false ,
2007-06-11 23:25:46 +00:00
'formatter' => false ,
'util' => false ,
2007-01-07 14:52:16 +00:00
);
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-05-30 12:09:24 +00:00
* Constructor .
2007-01-07 14:52:16 +00:00
*
2008-07-04 16:32:19 +00:00
* @ param array $params The connection parameters .
2007-01-07 14:52:16 +00:00
*/
2008-06-05 19:01:58 +00:00
public function __construct ( array $params )
2007-01-07 14:52:16 +00:00
{
2008-06-05 19:01:58 +00:00
if ( isset ( $params [ 'pdo' ])) {
2008-07-04 16:32:19 +00:00
$this -> _pdo = $params [ 'pdo' ];
$this -> _isConnected = true ;
2007-06-12 19:39:03 +00:00
}
2008-06-05 19:01:58 +00:00
$this -> _params = $params ;
}
/**
* Sets the Configuration used by the Connection .
*
* @ param Doctrine_Configuration $config
*/
public function setConfiguration ( Doctrine_Configuration $config )
{
$this -> _config = $config ;
}
/**
* Gets the Configuration used by the Connection .
*
* @ return Configuration
*/
public function getConfiguration ()
{
if ( ! $this -> _config ) {
$this -> _config = new Doctrine_Configuration ();
}
return $this -> _config ;
}
/**
* Sets the EventManager used by the Connection .
*
* @ param Doctrine_EventManager $eventManager
*/
public function setEventManager ( Doctrine_EventManager $eventManager )
{
$this -> _eventManager = $eventManager ;
}
/**
* Gets the EventManager used by the Connection .
*
* @ return EventManager
*/
public function getEventManager ()
{
if ( ! $this -> _eventManager ) {
$this -> _eventManager = new Doctrine_EventManager ();
}
return $this -> _eventManager ;
2007-01-07 14:52:16 +00:00
}
2008-05-06 13:41:22 +00:00
2008-06-15 15:56:28 +00:00
public function getProperty ( $name )
{
if ( ! isset ( $this -> properties [ $name ])) {
throw Doctrine_Connection_Exception :: unknownProperty ( $name );
}
return $this -> properties [ $name ];
}
2007-06-12 19:39:03 +00:00
/**
* returns an array of available PDO drivers
*/
public static function getAvailableDrivers ()
{
return PDO :: getAvailableDrivers ();
}
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
* getName
* returns the name of this driver
*
* @ return string the name of this driver
*/
public function getName ()
2008-01-22 21:42:17 +00:00
{
return $this -> _name ;
}
2008-05-06 13:41:22 +00:00
2008-02-15 18:42:06 +00:00
/**
* setName
*
* Sets the name of the connection
*
* @ param string $name
* @ return void
*/
2008-01-22 21:42:17 +00:00
public function setName ( $name )
{
$this -> _name = $name ;
}
2008-01-29 09:59:37 +00:00
2008-02-15 18:42:06 +00:00
/**
* Gets the name of the instance driver
*
* @ return void
*/
2008-01-22 21:42:17 +00:00
public function getDriverName ()
2007-01-07 14:52:16 +00:00
{
2008-07-04 16:32:19 +00:00
return $this -> _driverName ;
2007-01-07 14:52:16 +00:00
}
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-01-12 19:49:11 +00:00
* returns the database handler which this connection uses
2007-01-07 14:52:16 +00:00
*
* @ return PDO the database handler
2008-07-04 16:32:19 +00:00
* @ deprecated
2007-01-07 14:52:16 +00:00
*/
public function getDbh ()
{
2008-07-04 16:32:19 +00:00
$this -> connect ();
return $this -> _pdo ;
}
/**
* Gets the PDO handle used by the connection .
*
* @ return PDO
*/
public function getPdo ()
{
$this -> connect ();
return $this -> _pdo ;
2007-01-07 14:52:16 +00:00
}
2008-05-06 13:41:22 +00:00
2007-06-11 23:25:46 +00:00
/**
2008-02-03 21:29:57 +00:00
* Establishes the connection with the database .
2007-06-11 23:25:46 +00:00
*
* @ return boolean
*/
public function connect ()
{
2008-07-04 16:32:19 +00:00
if ( $this -> _isConnected ) {
2007-06-11 23:25:46 +00:00
return false ;
}
2008-05-24 18:18:37 +00:00
//$event = new Doctrine_Event($this, Doctrine_Event::CONN_CONNECT);
//$this->getListener()->preConnect($event);
2007-06-11 23:25:46 +00:00
2008-07-04 16:32:19 +00:00
// TODO: the extension_loaded check can happen earlier, maybe in the factory
2008-07-20 20:13:24 +00:00
if ( ! extension_loaded ( 'pdo' )) {
2008-05-17 20:04:56 +00:00
throw new Doctrine_Connection_Exception ( " Couldn't locate driver named " . $e [ 0 ]);
2007-06-11 23:25:46 +00:00
}
2008-07-20 20:13:24 +00:00
$driverOptions = isset ( $this -> _params [ 'driverOptions' ]) ?
$this -> _params [ 'driverOptions' ] : array ();
$user = isset ( $this -> _params [ 'user' ]) ?
$this -> _params [ 'user' ] : null ;
$password = isset ( $this -> _params [ 'password' ]) ?
$this -> _params [ 'password' ] : null ;
$this -> _pdo = new PDO (
$this -> _constructPdoDsn (),
$user ,
$password ,
$driverOptions
);
$this -> _pdo -> setAttribute ( PDO :: ATTR_ERRMODE , PDO :: ERRMODE_EXCEPTION );
$this -> _pdo -> setAttribute ( PDO :: ATTR_CASE , PDO :: CASE_LOWER );
2007-06-11 23:25:46 +00:00
2007-06-12 19:39:03 +00:00
// attach the pending attributes to adapter
2008-07-04 16:32:19 +00:00
/* foreach ( $this -> pendingAttributes as $attr => $value ) {
2007-06-11 23:25:46 +00:00
// some drivers don't support setting this so we just skip it
2007-09-03 14:57:18 +00:00
if ( $attr == Doctrine :: ATTR_DRIVER_NAME ) {
2007-06-11 23:25:46 +00:00
continue ;
}
2008-07-04 16:32:19 +00:00
$this -> _pdo -> setAttribute ( $attr , $value );
} */
2007-06-11 23:25:46 +00:00
2008-07-04 16:32:19 +00:00
$this -> _isConnected = true ;
2007-06-11 23:25:46 +00:00
2008-05-24 18:18:37 +00:00
//$this->getListener()->postConnect($event);
2007-06-11 23:25:46 +00:00
return true ;
}
2008-02-03 21:29:57 +00:00
2008-06-05 19:01:58 +00:00
/**
* Constructs the PDO DSN for use in the PDO constructor .
* Concrete connection implementations override this implementation to
* create the proper DSN .
*
* @ return string
* @ todo make abstract , implement in subclasses .
*/
protected function _constructPdoDsn ()
{
2008-07-04 16:32:19 +00:00
throw Doctrine_Exception :: notImplemented ( '_constructPdoDsn' , get_class ( $this ));
2008-06-05 19:01:58 +00:00
}
2008-02-03 21:29:57 +00:00
/**
* @ todo Remove . Breaks encapsulation .
*/
public function incrementQueryCount ()
2007-06-19 23:33:04 +00:00
{
2008-07-04 16:32:19 +00:00
$this -> _queryCount ++ ;
2007-06-19 23:33:04 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-07-04 16:32:19 +00:00
* Checks whether a certain feature is supported .
2007-01-07 14:52:16 +00:00
*
* @ param string $feature the name of the feature
* @ return boolean whether or not this drivers supports given feature
*/
public function supports ( $feature )
{
2008-07-20 20:13:24 +00:00
return ( isset ( $this -> supported [ $feature ]) &&
( $this -> supported [ $feature ] === 'emulated' || $this -> supported [ $feature ]));
2007-01-07 14:52:16 +00:00
}
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
* Execute a SQL REPLACE query . A REPLACE query is identical to a INSERT
* query , except that if there is already a row in the table with the same
* key field values , the REPLACE query just updates its values instead of
* inserting a new row .
*
* The REPLACE type of query does not make part of the SQL standards . Since
* practically only MySQL and SQLIte implement it natively , this type of
* query isemulated through this method for other DBMS using standard types
* of queries inside a transaction to assure the atomicity of the operation .
*
* @ param string name of the table on which the REPLACE query will
* be executed .
*
* @ param array an associative array that describes the fields and the
* values that will be inserted or updated in the specified table . The
* indexes of the array are the names of all the fields of the table .
*
* The values of the array are values to be assigned to the specified field .
*
* @ param array $keys an array containing all key fields ( primary key fields
* or unique index fields ) for this table
*
* the uniqueness of a row will be determined according to
* the provided key fields
*
* this method will fail if no key fields are specified
*
* @ throws Doctrine_Connection_Exception if this driver doesn ' t support replace
* @ throws Doctrine_Connection_Exception if some of the key values was null
* @ throws Doctrine_Connection_Exception if there were no key fields
* @ throws PDOException if something fails at PDO level
2008-02-03 21:29:57 +00:00
* @ return integer number of rows affected
2007-01-07 14:52:16 +00:00
*/
2008-02-12 12:31:28 +00:00
public function replace ( $tableName , array $data , array $keys )
2007-01-07 14:52:16 +00:00
{
if ( empty ( $keys )) {
throw new Doctrine_Connection_Exception ( 'Not specified which fields are keys' );
}
$condition = $values = array ();
2008-02-12 12:31:28 +00:00
foreach ( $data as $columnName => $value ) {
$values [ $columnName ] = $value ;
2007-01-07 14:52:16 +00:00
2008-02-12 12:31:28 +00:00
if ( in_array ( $columnName , $keys )) {
2007-01-07 14:52:16 +00:00
if ( $value === null )
2008-02-12 12:31:28 +00:00
throw new Doctrine_Connection_Exception ( 'key value ' . $columnName . ' may not be null' );
2007-01-07 14:52:16 +00:00
2008-02-12 12:31:28 +00:00
$condition [] = $columnName . ' = ?' ;
2007-01-07 14:52:16 +00:00
$conditionValues [] = $value ;
}
}
2008-02-12 12:31:28 +00:00
$query = 'DELETE FROM ' . $this -> quoteIdentifier ( $tableName )
2007-11-18 16:06:37 +00:00
. ' WHERE ' . implode ( ' AND ' , $condition );
$affectedRows = $this -> exec ( $query , $conditionValues );
2007-01-07 14:52:16 +00:00
$this -> insert ( $table , $values );
$affectedRows ++ ;
return $affectedRows ;
}
2007-10-21 06:23:59 +00:00
2007-11-10 10:37:10 +00:00
/**
2008-02-12 12:31:28 +00:00
* Deletes table row ( s ) matching the specified identifier .
2007-11-10 10:37:10 +00:00
*
* @ throws Doctrine_Connection_Exception if something went wrong at the database level
* @ param string $table The table to delete data from
2008-01-12 19:49:11 +00:00
* @ param array $identifier An associateve array containing identifier fieldname - value pairs .
2007-11-10 10:37:10 +00:00
* @ return integer The number of affected rows
*/
2008-02-12 12:31:28 +00:00
public function delete ( $tableName , array $identifier )
2007-11-10 10:37:10 +00:00
{
2008-01-12 19:49:11 +00:00
$criteria = array ();
2007-11-10 10:37:10 +00:00
foreach ( array_keys ( $identifier ) as $id ) {
2008-02-27 02:17:42 +00:00
$criteria [] = $this -> quoteIdentifier ( $id ) . ' = ?' ;
2007-11-10 10:37:10 +00:00
}
$query = 'DELETE FROM '
2008-02-12 12:31:28 +00:00
. $this -> quoteIdentifier ( $tableName )
2008-01-12 19:49:11 +00:00
. ' WHERE ' . implode ( ' AND ' , $criteria );
2007-11-10 10:37:10 +00:00
2007-11-10 13:21:40 +00:00
return $this -> exec ( $query , array_values ( $identifier ));
2007-11-10 10:37:10 +00:00
}
2007-11-10 00:57:13 +00:00
/**
* Updates table row ( s ) with specified data
*
* @ throws Doctrine_Connection_Exception if something went wrong at the database level
* @ param string $table The table to insert data into
* @ param array $values An associateve array containing column - value pairs .
* @ return mixed boolean false if empty value array was given ,
* otherwise returns the number of affected rows
*/
2008-02-12 12:31:28 +00:00
public function update ( $tableName , array $data , array $identifier )
2007-11-10 00:57:13 +00:00
{
2008-02-12 12:31:28 +00:00
if ( empty ( $data )) {
2007-11-10 00:57:13 +00:00
return false ;
}
$set = array ();
2008-02-12 12:31:28 +00:00
foreach ( $data as $columnName => $value ) {
2007-11-10 00:57:13 +00:00
if ( $value instanceof Doctrine_Expression ) {
2008-02-27 02:17:42 +00:00
$set [] = $this -> quoteIdentifier ( $columnName ) . ' = ' . $value -> getSql ();
2008-02-12 12:31:28 +00:00
unset ( $data [ $columnName ]);
2007-11-10 00:57:13 +00:00
} else {
2008-02-27 02:17:42 +00:00
$set [] = $this -> quoteIdentifier ( $columnName ) . ' = ?' ;
2007-11-10 00:57:13 +00:00
}
}
2008-02-12 12:31:28 +00:00
$params = array_merge ( array_values ( $data ), array_values ( $identifier ));
2007-11-10 00:57:13 +00:00
2008-02-12 12:31:28 +00:00
$sql = 'UPDATE ' . $this -> quoteIdentifier ( $tableName )
2007-11-10 00:57:13 +00:00
. ' SET ' . implode ( ', ' , $set )
2008-02-12 12:31:28 +00:00
. ' WHERE ' . implode ( ' = ? AND ' , array_keys ( $identifier ))
2007-11-10 00:57:13 +00:00
. ' = ?' ;
return $this -> exec ( $sql , $params );
}
2007-01-07 14:52:16 +00:00
/**
* Inserts a table row with specified data .
*
* @ param string $table The table to insert data into .
2008-01-12 19:49:11 +00:00
* @ param array $fields An associateve array containing fieldname - value pairs .
2007-11-10 10:37:10 +00:00
* @ return mixed boolean false if empty value array was given ,
* otherwise returns the number of affected rows
2007-01-07 14:52:16 +00:00
*/
2008-02-12 12:31:28 +00:00
public function insert ( $tableName , array $data )
2008-01-05 19:55:56 +00:00
{
2008-02-12 12:31:28 +00:00
if ( empty ( $data )) {
2007-01-07 14:52:16 +00:00
return false ;
}
2007-08-25 00:34:25 +00:00
// column names are specified as array keys
$cols = array ();
// the query VALUES will contain either expresions (eg 'NOW()') or ?
2007-07-01 11:27:45 +00:00
$a = array ();
2008-02-12 12:31:28 +00:00
foreach ( $data as $columnName => $value ) {
$cols [] = $this -> quoteIdentifier ( $columnName );
2007-07-01 11:27:45 +00:00
if ( $value instanceof Doctrine_Expression ) {
2007-08-25 00:34:25 +00:00
$a [] = $value -> getSql ();
2008-02-12 12:31:28 +00:00
unset ( $data [ $columnName ]);
2007-07-01 11:27:45 +00:00
} else {
2007-08-25 00:34:25 +00:00
$a [] = '?' ;
2007-07-01 11:27:45 +00:00
}
}
2008-01-29 09:59:37 +00:00
2007-08-25 00:34:25 +00:00
// build the statement
2008-01-29 09:59:37 +00:00
$query = 'INSERT INTO ' . $this -> quoteIdentifier ( $tableName )
2007-08-25 00:34:25 +00:00
. ' (' . implode ( ', ' , $cols ) . ') '
. 'VALUES (' ;
2007-07-01 11:27:45 +00:00
$query .= implode ( ', ' , $a ) . ')' ;
2007-01-07 14:52:16 +00:00
// prepare and execute the statement
2008-02-28 15:30:55 +00:00
2008-02-12 12:31:28 +00:00
return $this -> exec ( $query , array_values ( $data ));
2008-01-29 09:59:37 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* Set the charset on the current connection
*
* @ param string charset
*/
public function setCharset ( $charset )
{
2008-01-12 19:49:11 +00:00
return true ;
2007-05-27 18:56:04 +00:00
}
2007-10-21 06:23:59 +00:00
2007-05-27 18:56:04 +00:00
/**
2008-01-12 19:49:11 +00:00
* Quote a string so it can be safely used as a table or column name .
2007-05-27 18:56:04 +00:00
*
* Delimiting style depends on which database driver is being used .
*
* NOTE : just because you CAN use delimited identifiers doesn ' t mean
* you SHOULD use them . In general , they end up causing way more
* problems than they solve .
*
* Portability is broken by using the following characters inside
* delimited identifiers :
* + backtick ( < kbd > ` </ kbd > ) -- due to MySQL
* + double quote ( < kbd > " </kbd>) -- due to Oracle
* + brackets ( < kbd > [ </ kbd > or < kbd > ] </ kbd > ) -- due to Access
*
* Delimited identifiers are known to generally work correctly under
* the following drivers :
* + mssql
* + mysql
* + mysqli
* + oci8
* + pgsql
* + sqlite
*
* InterBase doesn ' t seem to be able to use delimited identifiers
* via PHP 4. They work fine under PHP 5.
*
* @ param string $str identifier name to be quoted
* @ param bool $checkOption check the 'quote_identifier' option
*
* @ return string quoted identifier string
*/
public function quoteIdentifier ( $str , $checkOption = true )
{
2007-09-03 14:57:18 +00:00
// quick fix for the identifiers that contain a dot
2007-07-12 22:31:16 +00:00
if ( strpos ( $str , '.' )) {
$e = explode ( '.' , $str );
2008-01-29 09:59:37 +00:00
2008-06-15 15:56:28 +00:00
return $this -> getFormatter () -> quoteIdentifier ( $e [ 0 ], $checkOption ) . '.'
. $this -> getFormatter () -> quoteIdentifier ( $e [ 1 ], $checkOption );
2007-07-12 22:31:16 +00:00
}
2008-06-15 15:56:28 +00:00
return $this -> getFormatter () -> quoteIdentifier ( $str , $checkOption );
2007-05-27 18:56:04 +00:00
}
2007-10-21 06:23:59 +00:00
2007-05-27 18:56:04 +00:00
/**
* convertBooleans
* some drivers need the boolean values to be converted into integers
* when using DQL API
*
* This method takes care of that conversion
*
* @ param array $item
* @ return void
*/
public function convertBooleans ( $item )
{
2008-06-15 15:56:28 +00:00
return $this -> getFormatter () -> convertBooleans ( $item );
2007-05-27 18:56:04 +00:00
}
2007-10-21 06:23:59 +00:00
2007-05-27 18:56:04 +00:00
/**
2008-07-20 20:13:24 +00:00
* Quotes given input parameter
2007-05-27 18:56:04 +00:00
*
* @ param mixed $input parameter to be quoted
* @ param string $type
* @ return mixed
*/
public function quote ( $input , $type = null )
{
2008-07-04 16:32:19 +00:00
return $this -> _pdo -> quote ( $input , $type );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-20 11:44:41 +00:00
/**
* Set the date / time format for the current connection
*
* @ param string time format
*
* @ return void
*/
public function setDateFormat ( $format = null )
{
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* fetchAll
*
* @ param string $statement sql query to be executed
* @ param array $params prepared statement params
* @ return array
*/
2008-01-29 09:59:37 +00:00
public function fetchAll ( $statement , array $params = array ())
2007-01-24 22:50:49 +00:00
{
2007-06-25 17:24:20 +00:00
return $this -> execute ( $statement , $params ) -> fetchAll ( Doctrine :: FETCH_ASSOC );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* fetchOne
*
* @ param string $statement sql query to be executed
* @ param array $params prepared statement params
* @ param int $colnum 0 - indexed column number to retrieve
* @ return mixed
*/
2008-01-29 09:59:37 +00:00
public function fetchOne ( $statement , array $params = array (), $colnum = 0 )
2007-01-24 22:50:49 +00:00
{
2007-01-07 14:52:16 +00:00
return $this -> execute ( $statement , $params ) -> fetchColumn ( $colnum );
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* fetchRow
*
* @ param string $statement sql query to be executed
* @ param array $params prepared statement params
* @ return array
*/
2008-01-29 09:59:37 +00:00
public function fetchRow ( $statement , array $params = array ())
2007-01-24 22:50:49 +00:00
{
2007-06-25 17:24:20 +00:00
return $this -> execute ( $statement , $params ) -> fetch ( Doctrine :: FETCH_ASSOC );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* fetchArray
*
* @ param string $statement sql query to be executed
* @ param array $params prepared statement params
* @ return array
*/
2008-01-29 09:59:37 +00:00
public function fetchArray ( $statement , array $params = array ())
2007-01-24 22:50:49 +00:00
{
2007-06-25 17:24:20 +00:00
return $this -> execute ( $statement , $params ) -> fetch ( Doctrine :: FETCH_NUM );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* fetchColumn
*
* @ param string $statement sql query to be executed
* @ param array $params prepared statement params
* @ param int $colnum 0 - indexed column number to retrieve
* @ return array
*/
2008-01-29 09:59:37 +00:00
public function fetchColumn ( $statement , array $params = array (), $colnum = 0 )
2007-01-24 22:50:49 +00:00
{
2007-06-25 17:24:20 +00:00
return $this -> execute ( $statement , $params ) -> fetchAll ( Doctrine :: FETCH_COLUMN , $colnum );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* fetchAssoc
*
* @ param string $statement sql query to be executed
* @ param array $params prepared statement params
* @ return array
*/
2008-01-29 09:59:37 +00:00
public function fetchAssoc ( $statement , array $params = array ())
2007-01-24 22:50:49 +00:00
{
2007-06-25 17:24:20 +00:00
return $this -> execute ( $statement , $params ) -> fetchAll ( Doctrine :: FETCH_ASSOC );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* fetchBoth
*
* @ param string $statement sql query to be executed
* @ param array $params prepared statement params
* @ return array
*/
2008-01-29 09:59:37 +00:00
public function fetchBoth ( $statement , array $params = array ())
2007-01-24 22:50:49 +00:00
{
2007-06-25 17:24:20 +00:00
return $this -> execute ( $statement , $params ) -> fetchAll ( Doctrine :: FETCH_BOTH );
2007-01-07 14:52:16 +00:00
}
2008-05-06 13:41:22 +00:00
2007-06-19 23:33:04 +00:00
/**
* prepare
*
* @ param string $statement
*/
public function prepare ( $statement )
{
$this -> connect ();
2007-07-11 22:03:47 +00:00
try {
$event = new Doctrine_Event ( $this , Doctrine_Event :: CONN_PREPARE , $statement );
2008-03-26 11:10:45 +00:00
2007-07-11 22:03:47 +00:00
$this -> getAttribute ( Doctrine :: ATTR_LISTENER ) -> prePrepare ( $event );
2007-06-19 23:33:04 +00:00
2007-07-11 22:03:47 +00:00
$stmt = false ;
2008-03-26 11:10:45 +00:00
2007-07-11 22:03:47 +00:00
if ( ! $event -> skipOperation ) {
2008-07-04 16:32:19 +00:00
$stmt = $this -> _pdo -> prepare ( $statement );
2007-07-11 22:03:47 +00:00
}
2008-03-26 11:10:45 +00:00
2007-07-11 22:03:47 +00:00
$this -> getAttribute ( Doctrine :: ATTR_LISTENER ) -> postPrepare ( $event );
2008-03-26 11:10:45 +00:00
2007-07-11 22:03:47 +00:00
return new Doctrine_Connection_Statement ( $this , $stmt );
2008-07-20 20:13:24 +00:00
} catch ( PDOException $e ) {
$this -> rethrowException ( $e , $this );
}
2007-06-19 23:33:04 +00:00
}
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
* queries the database with limit and offset
2007-10-13 17:06:26 +00:00
* added to the query and returns a Doctrine_Connection_Statement object
2007-01-07 14:52:16 +00:00
*
* @ param string $query
* @ param integer $limit
* @ param integer $offset
2007-10-13 17:06:26 +00:00
* @ return Doctrine_Connection_Statement
2007-01-07 14:52:16 +00:00
*/
2007-06-12 19:39:03 +00:00
public function select ( $query , $limit = 0 , $offset = 0 )
2007-01-07 14:52:16 +00:00
{
if ( $limit > 0 || $offset > 0 ) {
$query = $this -> modifyLimitQuery ( $query , $limit , $offset );
}
2007-10-13 17:06:26 +00:00
return $this -> execute ( $query );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-24 22:50:49 +00:00
/**
* standaloneQuery
*
* @ param string $query sql query
* @ param array $params query parameters
*
* @ return PDOStatement | Doctrine_Adapter_Statement
*/
public function standaloneQuery ( $query , $params = array ())
{
return $this -> execute ( $query , $params );
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* execute
* @ param string $query sql query
* @ param array $params query parameters
*
* @ return PDOStatement | Doctrine_Adapter_Statement
*/
2007-06-25 10:08:03 +00:00
public function execute ( $query , array $params = array ())
2007-01-24 22:50:49 +00:00
{
2007-09-03 14:57:18 +00:00
$this -> connect ();
2007-06-12 19:39:03 +00:00
2007-01-07 14:52:16 +00:00
try {
if ( ! empty ( $params )) {
2007-06-26 22:29:31 +00:00
$stmt = $this -> prepare ( $query );
2007-01-07 14:52:16 +00:00
$stmt -> execute ( $params );
2007-05-27 18:56:04 +00:00
return $stmt ;
2007-01-07 14:52:16 +00:00
} else {
2007-06-25 17:24:20 +00:00
$event = new Doctrine_Event ( $this , Doctrine_Event :: CONN_QUERY , $query , $params );
2007-06-19 23:33:04 +00:00
2007-06-25 10:08:03 +00:00
$this -> getAttribute ( Doctrine :: ATTR_LISTENER ) -> preQuery ( $event );
2007-06-19 23:33:04 +00:00
2007-06-25 10:08:03 +00:00
if ( ! $event -> skipOperation ) {
2008-07-04 16:32:19 +00:00
$stmt = $this -> _pdo -> query ( $query );
$this -> _queryCount ++ ;
2007-06-25 10:08:03 +00:00
}
$this -> getAttribute ( Doctrine :: ATTR_LISTENER ) -> postQuery ( $event );
2007-06-19 23:33:04 +00:00
return $stmt ;
2007-01-07 14:52:16 +00:00
}
2008-07-20 20:13:24 +00:00
} catch ( PDOException $e ) {
$this -> rethrowException ( $e , $this );
}
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* exec
* @ param string $query sql query
* @ param array $params query parameters
*
* @ return PDOStatement | Doctrine_Adapter_Statement
*/
public function exec ( $query , array $params = array ()) {
2007-09-03 14:57:18 +00:00
$this -> connect ();
2007-09-01 17:35:44 +00:00
2007-01-07 14:52:16 +00:00
try {
if ( ! empty ( $params )) {
2007-06-19 23:33:04 +00:00
$stmt = $this -> prepare ( $query );
2007-01-07 14:52:16 +00:00
$stmt -> execute ( $params );
2008-05-06 13:41:22 +00:00
2007-01-15 18:48:50 +00:00
return $stmt -> rowCount ();
2007-01-07 14:52:16 +00:00
} else {
2007-06-25 17:24:20 +00:00
$event = new Doctrine_Event ( $this , Doctrine_Event :: CONN_EXEC , $query , $params );
2007-06-19 23:33:04 +00:00
2007-06-25 10:08:03 +00:00
$this -> getAttribute ( Doctrine :: ATTR_LISTENER ) -> preExec ( $event );
2007-06-19 23:33:04 +00:00
2007-06-25 10:08:03 +00:00
if ( ! $event -> skipOperation ) {
2008-07-04 16:32:19 +00:00
$count = $this -> _pdo -> exec ( $query );
$this -> _queryCount ++ ;
2007-06-25 10:08:03 +00:00
}
$this -> getAttribute ( Doctrine :: ATTR_LISTENER ) -> postExec ( $event );
2007-06-19 23:33:04 +00:00
return $count ;
2007-01-07 14:52:16 +00:00
}
2008-07-20 20:13:24 +00:00
} catch ( PDOException $e ) {
$this -> rethrowException ( $e , $this );
}
2007-01-07 14:52:16 +00:00
}
2008-05-17 12:22:24 +00:00
/**
*
*
* @ return string
*/
2008-05-24 18:51:47 +00:00
public function modifyLimitQuery ( $query , $limit = false , $offset = false , $isManip = false )
2008-05-17 12:22:24 +00:00
{
return $query ;
}
/**
* Creates dbms specific LIMIT / OFFSET SQL for the subqueries that are used in the
* context of the limit - subquery algorithm .
*
* @ return string
*/
public function modifyLimitSubquery ( Doctrine_Table $rootTable , $query , $limit = false ,
$offset = false , $isManip = false )
{
return $this -> modifyLimitQuery ( $query , $limit , $offset , $isManip );
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-07-20 20:13:24 +00:00
* Wraps the given exception into a driver - specific exception and rethrows it .
2007-01-07 14:52:16 +00:00
*
* @ throws Doctrine_Connection_Exception
*/
2007-07-11 22:03:47 +00:00
public function rethrowException ( Exception $e , $invoker )
2007-01-07 14:52:16 +00:00
{
2008-06-15 15:56:28 +00:00
//$event = new Doctrine_Event($this, Doctrine_Event::CONN_ERROR);
//$this->getListener()->preError($event);
2008-02-03 21:29:57 +00:00
2008-07-04 16:32:19 +00:00
$name = 'Doctrine_Connection_' . $this -> _driverName . '_Exception' ;
2008-05-06 13:41:22 +00:00
2008-01-05 19:55:56 +00:00
$exc = new $name ( $e -> getMessage (), ( int ) $e -> getCode ());
2007-01-07 14:52:16 +00:00
if ( ! is_array ( $e -> errorInfo )) {
$e -> errorInfo = array ( null , null , null , null );
}
$exc -> processErrorInfo ( $e -> errorInfo );
2008-07-20 20:13:24 +00:00
throw $exc ;
2008-01-29 09:59:37 +00:00
2008-06-15 15:56:28 +00:00
//$this->getListener()->postError($event);
2007-01-07 14:52:16 +00:00
}
2008-02-20 20:54:20 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-02-03 21:29:57 +00:00
* Returns the number of queries executed by the connection .
2007-01-07 14:52:16 +00:00
*
* @ return integer
2008-02-03 21:29:57 +00:00
* @ todo Better name : getQueryCount ()
2007-01-07 14:52:16 +00:00
*/
public function count ()
{
2008-07-04 16:32:19 +00:00
return $this -> _queryCount ;
2007-01-07 14:52:16 +00:00
}
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-02-03 21:29:57 +00:00
* Closes the connection .
2007-01-07 14:52:16 +00:00
*
* @ return void
*/
public function close ()
{
2008-06-15 15:56:28 +00:00
//$event = new Doctrine_Event($this, Doctrine_Event::CONN_CLOSE);
//this->getAttribute(Doctrine::ATTR_LISTENER)->preClose($event);
2007-01-07 14:52:16 +00:00
$this -> clear ();
2008-01-29 09:59:37 +00:00
2008-07-04 16:32:19 +00:00
unset ( $this -> _pdo );
$this -> _isConnected = false ;
2007-01-07 14:52:16 +00:00
2008-06-15 15:56:28 +00:00
//$this->getAttribute(Doctrine::ATTR_LISTENER)->postClose($event);
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
2008-02-03 21:29:57 +00:00
* Returns the current total transaction nesting level .
2007-01-07 14:52:16 +00:00
*
2008-02-03 21:29:57 +00:00
* @ return integer The nesting level . A value of 0 means theres no active transaction .
2007-01-07 14:52:16 +00:00
*/
public function getTransactionLevel ()
{
return $this -> transaction -> getTransactionLevel ();
}
2008-05-06 13:41:22 +00:00
2007-06-12 19:39:03 +00:00
/**
* errorCode
* Fetch the SQLSTATE associated with the last operation on the database handle
*
* @ return integer
*/
public function errorCode ()
{
2007-09-03 14:57:18 +00:00
$this -> connect ();
2008-02-03 21:29:57 +00:00
2008-07-04 16:32:19 +00:00
return $this -> _pdo -> errorCode ();
2007-06-12 19:39:03 +00:00
}
2007-10-21 06:23:59 +00:00
2007-06-12 19:39:03 +00:00
/**
* errorInfo
* Fetch extended error information associated with the last operation on the database handle
*
* @ return array
*/
public function errorInfo ()
{
2007-09-03 14:57:18 +00:00
$this -> connect ();
2008-02-03 21:29:57 +00:00
2008-07-04 16:32:19 +00:00
return $this -> _pdo -> errorInfo ();
2007-06-12 19:39:03 +00:00
}
2008-05-06 13:41:22 +00:00
2007-11-24 18:11:09 +00:00
/**
2008-05-06 13:41:22 +00:00
* lastInsertId
2007-06-11 23:37:24 +00:00
*
* Returns the ID of the last inserted row , or the last value from a sequence object ,
* depending on the underlying driver .
*
2008-01-29 09:59:37 +00:00
* Note : This method may not return a meaningful or consistent result across different drivers ,
2007-06-11 23:37:24 +00:00
* because the underlying database may not even support the notion of auto - increment fields or sequences .
*
2008-02-03 21:29:57 +00:00
* @ param string $table Name of the table into which a new row was inserted .
* @ param string $field Name of the field into which a new row was inserted .
2007-06-11 23:37:24 +00:00
*/
public function lastInsertId ( $table = null , $field = null )
{
return $this -> sequence -> lastInsertId ( $table , $field );
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
* beginTransaction
2007-06-11 23:25:46 +00:00
* Start a transaction or set a savepoint .
2007-01-07 14:52:16 +00:00
*
2007-06-11 23:25:46 +00:00
* if trying to set a savepoint and there is no active transaction
* a new transaction is being started
2007-01-07 14:52:16 +00:00
*
2007-06-11 23:25:46 +00:00
* Listeners : onPreTransactionBegin , onTransactionBegin
*
* @ param string $savepoint name of a savepoint to set
* @ throws Doctrine_Transaction_Exception if the transaction fails at database level
* @ return integer current transaction nesting level
2007-01-07 14:52:16 +00:00
*/
2007-06-11 23:25:46 +00:00
public function beginTransaction ( $savepoint = null )
2007-01-07 14:52:16 +00:00
{
2007-12-19 22:45:14 +00:00
return $this -> transaction -> beginTransaction ( $savepoint );
2007-01-07 14:52:16 +00:00
}
2008-05-06 13:41:22 +00:00
2007-01-07 14:52:16 +00:00
/**
2007-06-11 23:25:46 +00:00
* commit
* Commit the database changes done during a transaction that is in
* progress or release a savepoint . This function may only be called when
* auto - committing is disabled , otherwise it will fail .
2007-01-07 14:52:16 +00:00
*
2007-06-11 23:25:46 +00:00
* Listeners : onPreTransactionCommit , onTransactionCommit
*
* @ param string $savepoint name of a savepoint to release
* @ throws Doctrine_Transaction_Exception if the transaction fails at PDO level
* @ throws Doctrine_Validator_Exception if the transaction fails due to record validations
* @ return boolean false if commit couldn ' t be performed , true otherwise
2007-01-07 14:52:16 +00:00
*/
2007-06-11 23:25:46 +00:00
public function commit ( $savepoint = null )
2007-01-07 14:52:16 +00:00
{
2007-12-19 22:45:14 +00:00
return $this -> transaction -> commit ( $savepoint );
2007-01-07 14:52:16 +00:00
}
2007-10-21 06:23:59 +00:00
2007-01-07 14:52:16 +00:00
/**
2007-06-11 23:25:46 +00:00
* Cancel any database changes done during a transaction or since a specific
* savepoint that is in progress . This function may only be called when
* auto - committing is disabled , otherwise it will fail . Therefore , a new
* transaction is implicitly started after canceling the pending changes .
2007-01-07 14:52:16 +00:00
*
2007-06-11 23:25:46 +00:00
* this method can be listened with onPreTransactionRollback and onTransactionRollback
* eventlistener methods
2007-01-07 14:52:16 +00:00
*
2008-06-15 15:56:28 +00:00
* @ param string $savepoint Name of a savepoint to rollback to .
* @ throws Doctrine_Transaction_Exception If the rollback operation fails at database level .
* @ return boolean FALSE if rollback couldn ' t be performed , TRUE otherwise .
2007-01-07 14:52:16 +00:00
*/
2007-06-11 23:25:46 +00:00
public function rollback ( $savepoint = null )
2007-01-07 14:52:16 +00:00
{
2007-06-11 23:25:46 +00:00
$this -> transaction -> rollback ( $savepoint );
2007-01-07 14:52:16 +00:00
}
2007-08-29 21:57:46 +00:00
2008-01-22 21:42:17 +00:00
/**
2008-06-15 15:56:28 +00:00
* Creates the database for the connection instance .
2008-01-22 21:58:03 +00:00
*
2008-06-15 15:56:28 +00:00
* @ return mixed Will return an instance of the exception thrown if the
* create database fails , otherwise it returns a string
* detailing the success .
2008-01-22 21:42:17 +00:00
*/
public function createDatabase ()
{
2008-01-22 21:58:03 +00:00
try {
if ( ! $dsn = $this -> getOption ( 'dsn' )) {
throw new Doctrine_Connection_Exception ( 'You must create your Doctrine_Connection by using a valid Doctrine style dsn in order to use the create/drop database functionality' );
}
2008-01-22 21:42:17 +00:00
2008-01-22 21:58:03 +00:00
$manager = $this -> getManager ();
2008-01-22 21:42:17 +00:00
2008-01-22 21:58:03 +00:00
$info = $manager -> parsePdoDsn ( $dsn );
$username = $this -> getOption ( 'username' );
$password = $this -> getOption ( 'password' );
2008-01-22 21:42:17 +00:00
2008-01-22 21:58:03 +00:00
// Make connection without database specified so we can create it
$connect = $manager -> openConnection ( new PDO ( $info [ 'scheme' ] . ':host=' . $info [ 'host' ], $username , $password ), 'tmp_connection' , false );
2008-01-22 21:42:17 +00:00
2008-01-22 21:58:03 +00:00
// Create database
$connect -> export -> createDatabase ( $info [ 'dbname' ]);
2008-01-22 21:42:17 +00:00
2008-01-22 21:58:03 +00:00
// Close the tmp connection with no database
$manager -> closeConnection ( $connect );
2008-01-22 21:42:17 +00:00
2008-01-22 21:58:03 +00:00
// Close original connection
$manager -> closeConnection ( $this );
// Reopen original connection with newly created database
$manager -> openConnection ( new PDO ( $info [ 'dsn' ], $username , $password ), $this -> getName (), true );
return 'Successfully created database for connection "' . $this -> getName () . '" named "' . $info [ 'dbname' ] . '"' ;
} catch ( Exception $e ) {
return $e ;
}
2008-01-22 21:42:17 +00:00
}
/**
* dropDatabase
*
2008-01-22 21:58:03 +00:00
* Method for dropping the database for the connection instance
*
2008-06-15 15:56:28 +00:00
* @ return mixed Will return an instance of the exception thrown if the drop
* database fails , otherwise it returns a string detailing the success .
2008-01-22 21:42:17 +00:00
*/
public function dropDatabase ()
{
try {
2008-01-22 21:58:03 +00:00
if ( ! $dsn = $this -> getOption ( 'dsn' )) {
throw new Doctrine_Connection_Exception ( 'You must create your Doctrine_Connection by using a valid Doctrine style dsn in order to use the create/drop database functionality' );
}
$info = $this -> getManager () -> parsePdoDsn ( $dsn );
2008-01-29 09:59:37 +00:00
2008-01-22 21:42:17 +00:00
$this -> export -> dropDatabase ( $info [ 'dbname' ]);
return 'Successfully dropped database for connection "' . $this -> getName () . '" named "' . $info [ 'dbname' ] . '"' ;
} catch ( Exception $e ) {
return $e ;
}
}
2007-01-07 14:52:16 +00:00
/**
* returns a string representation of this object
* @ return string
*/
public function __toString ()
{
return Doctrine_Lib :: getConnectionAsString ( $this );
}
2008-03-17 13:26:34 +00:00
2008-05-06 13:41:22 +00:00
/*
* ----------- Mixed methods ( need to figure out where they go ) ---------------
*/
/**
* getAttribute
* retrieves a database connection attribute
*
* @ param integer $attribute
* @ return mixed
2008-06-15 15:56:28 +00:00
* @ todo Implementation or remove if not needed . Configuration is the main
* container for all the attributes now .
2008-05-06 13:41:22 +00:00
*/
public function getAttribute ( $attribute )
{
2008-05-30 12:09:24 +00:00
if ( $attribute == Doctrine :: ATTR_QUOTE_IDENTIFIER ) {
return false ;
}
2008-05-06 13:41:22 +00:00
}
2008-06-15 15:56:28 +00:00
public function getFormatter ()
2008-05-30 12:09:24 +00:00
{
2008-06-15 15:56:28 +00:00
if ( ! $this -> modules [ 'formatter' ]) {
$this -> modules [ 'formatter' ] = new Doctrine_Formatter ( $this );
2008-05-06 13:41:22 +00:00
}
2008-06-15 15:56:28 +00:00
return $this -> modules [ 'formatter' ];
2008-05-06 13:41:22 +00:00
}
2008-07-20 20:13:24 +00:00
public function getSequenceModule ()
{
if ( ! $this -> modules [ 'sequence' ]) {
$class = " Doctrine_Sequence_ " . $this -> _driverName ;
$this -> modules [ 'sequence' ] = new $class ;
}
return $this -> modules [ 'sequence' ];
}
/**
* Gets the default ( preferred ) Id generation strategy of the database platform .
*
* @ todo Sure , the id generator types are more ORM functionality but they ' re
* still kind of dbal related . Maybe we need another set of classes ( DatabasePlatform ? )
* but im not so sure ...
*/
/*abstract*/ public function getDefaultIdGeneratorType ()
{
}
2008-01-29 09:59:37 +00:00
}