. */ namespace Doctrine\DBAL\Driver\IbmDb2; class Db2Connection implements \Doctrine\DBAL\Driver\Connection { private $_conn = null; public function __construct($dbname, $username, $password, $driverOptions = array(), $isPersistant = false) { if ($isPersistant) { $this->_conn = db2_pconnect($dbname, $username, $password, $driverOptions); } else { $this->_conn = db2_connect($dbname, $username, $password, $driverOptions); } if (!$this->_conn) { throw new Db2Exception(db2_conn_errormsg()); } } function prepare($sql) { $stmt = @db2_prepare($this->_conn, $sql); if (!$stmt) { throw new Db2Exception(db2_stmt_errormsg()); } return new Db2Statement($stmt); } function query() { $args = func_get_args(); $sql = $args[0]; $stmt = $this->prepare($sql); $stmt->execute(); return $stmt; } function quote($input, $type=\PDO::PARAM_STR) { $input = db2_escape_string($input); if ($type == \PDO::PARAM_INT ) { return $input; } else { return "'".$input."'"; } } function exec($statement) { $stmt = $this->prepare($statement); $stmt->execute(); return $stmt; } function lastInsertId($name = null) { $sql = 'SELECT IDENTITY_VAL_LOCAL() AS VAL FROM SYSIBM.SYSDUMMY1'; if ($stmt = $this->query($sql)) { if ($col = $stmt->fetchColumn()) { return $col; } } return false; } function beginTransaction() { db2_autocommit($this->_conn, DB2_AUTOCOMMIT_OFF); } function commit() { if (!db2_commit($this->_conn)) { throw new Db2Exception(db2_conn_errormsg($this->_conn)); } db2_autocommit($this->_conn, DB2_AUTOCOMMIT_ON); } function rollBack() { if (!db2_rollback($this->_conn)) { throw new Db2Exception(db2_conn_errormsg($this->_conn)); } db2_autocommit($this->_conn, DB2_AUTOCOMMIT_ON); } function errorCode() { return db2_conn_error($this->_conn); } function errorInfo() { return array( 0 => db2_conn_errormsg($this->_conn), 1 => $this->errorCode(), ); } }