2010-04-07 20:39:34 +02: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
|
|
|
|
* <http://www.doctrine-project.org>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Doctrine\DBAL\Driver\IbmDb2;
|
|
|
|
|
|
|
|
class Db2Connection implements \Doctrine\DBAL\Driver\Connection
|
|
|
|
{
|
|
|
|
private $_conn = null;
|
|
|
|
|
2010-04-08 22:40:53 +02:00
|
|
|
public function __construct(array $params, $username, $password, $driverOptions = array())
|
2010-04-07 20:39:34 +02:00
|
|
|
{
|
2010-04-08 22:40:53 +02:00
|
|
|
$isPersistant = (isset($params['persistent']) && $params['persistent'] == true);
|
|
|
|
|
2010-04-07 20:39:34 +02:00
|
|
|
if ($isPersistant) {
|
2010-04-08 22:40:53 +02:00
|
|
|
$this->_conn = db2_pconnect($params['dbname'], $username, $password, $driverOptions);
|
2010-04-07 20:39:34 +02:00
|
|
|
} else {
|
2010-04-08 22:40:53 +02:00
|
|
|
$this->_conn = db2_connect($params['dbname'], $username, $password, $driverOptions);
|
2010-04-07 20:39:34 +02:00
|
|
|
}
|
|
|
|
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();
|
2010-04-20 23:20:42 +02:00
|
|
|
return $stmt->rowCount();
|
2010-04-07 20:39:34 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function lastInsertId($name = null)
|
|
|
|
{
|
2010-04-20 23:20:42 +02:00
|
|
|
return db2_last_insert_id($this->_conn);
|
2010-04-07 20:39:34 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
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(),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|