DB2Connection.php 3.92 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
<?php
/*
 * 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
Benjamin Eberlei's avatar
Benjamin Eberlei committed
16
 * and is licensed under the MIT license. For more information, see
17
 * <http://www.doctrine-project.org>.
Benjamin Morel's avatar
Benjamin Morel committed
18
 */
19

Benjamin Eberlei's avatar
Benjamin Eberlei committed
20
namespace Doctrine\DBAL\Driver\IBMDB2;
21

Benjamin Eberlei's avatar
Benjamin Eberlei committed
22
class DB2Connection implements \Doctrine\DBAL\Driver\Connection
23
{
Benjamin Morel's avatar
Benjamin Morel committed
24 25 26
    /**
     * @var resource
     */
27 28
    private $_conn = null;

Benjamin Morel's avatar
Benjamin Morel committed
29 30 31 32 33 34 35 36
    /**
     * @param array  $params
     * @param string $username
     * @param string $password
     * @param array  $driverOptions
     *
     * @throws \Doctrine\DBAL\Driver\IBMDB2\DB2Exception
     */
37
    public function __construct(array $params, $username, $password, $driverOptions = array())
38
    {
39 40
        $isPersistant = (isset($params['persistent']) && $params['persistent'] == true);

41
        if ($isPersistant) {
42
            $this->_conn = db2_pconnect($params['dbname'], $username, $password, $driverOptions);
43
        } else {
44
            $this->_conn = db2_connect($params['dbname'], $username, $password, $driverOptions);
45
        }
46
        if ( ! $this->_conn) {
Benjamin Eberlei's avatar
Benjamin Eberlei committed
47
            throw new DB2Exception(db2_conn_errormsg());
48 49 50
        }
    }

Benjamin Morel's avatar
Benjamin Morel committed
51 52 53
    /**
     * {@inheritdoc}
     */
54
    public function prepare($sql)
55 56
    {
        $stmt = @db2_prepare($this->_conn, $sql);
57
        if ( ! $stmt) {
Benjamin Eberlei's avatar
Benjamin Eberlei committed
58
            throw new DB2Exception(db2_stmt_errormsg());
59
        }
Benjamin Eberlei's avatar
Benjamin Eberlei committed
60
        return new DB2Statement($stmt);
61
    }
62

Benjamin Morel's avatar
Benjamin Morel committed
63 64 65
    /**
     * {@inheritdoc}
     */
66
    public function query()
67 68 69 70 71 72 73 74
    {
        $args = func_get_args();
        $sql = $args[0];
        $stmt = $this->prepare($sql);
        $stmt->execute();
        return $stmt;
    }

Benjamin Morel's avatar
Benjamin Morel committed
75 76 77
    /**
     * {@inheritdoc}
     */
78
    public function quote($input, $type=\PDO::PARAM_STR)
79 80 81 82 83 84 85 86 87
    {
        $input = db2_escape_string($input);
        if ($type == \PDO::PARAM_INT ) {
            return $input;
        } else {
            return "'".$input."'";
        }
    }

Benjamin Morel's avatar
Benjamin Morel committed
88 89 90
    /**
     * {@inheritdoc}
     */
91
    public function exec($statement)
92 93 94
    {
        $stmt = $this->prepare($statement);
        $stmt->execute();
95
        return $stmt->rowCount();
96 97
    }

Benjamin Morel's avatar
Benjamin Morel committed
98 99 100
    /**
     * {@inheritdoc}
     */
101
    public function lastInsertId($name = null)
102
    {
103
        return db2_last_insert_id($this->_conn);
104 105
    }

Benjamin Morel's avatar
Benjamin Morel committed
106 107 108
    /**
     * {@inheritdoc}
     */
109
    public function beginTransaction()
110 111 112 113
    {
        db2_autocommit($this->_conn, DB2_AUTOCOMMIT_OFF);
    }

Benjamin Morel's avatar
Benjamin Morel committed
114 115 116
    /**
     * {@inheritdoc}
     */
117
    public function commit()
118 119
    {
        if (!db2_commit($this->_conn)) {
Benjamin Eberlei's avatar
Benjamin Eberlei committed
120
            throw new DB2Exception(db2_conn_errormsg($this->_conn));
121 122 123 124
        }
        db2_autocommit($this->_conn, DB2_AUTOCOMMIT_ON);
    }

Benjamin Morel's avatar
Benjamin Morel committed
125 126 127
    /**
     * {@inheritdoc}
     */
128
    public function rollBack()
129 130
    {
        if (!db2_rollback($this->_conn)) {
Benjamin Eberlei's avatar
Benjamin Eberlei committed
131
            throw new DB2Exception(db2_conn_errormsg($this->_conn));
132 133 134 135
        }
        db2_autocommit($this->_conn, DB2_AUTOCOMMIT_ON);
    }

Benjamin Morel's avatar
Benjamin Morel committed
136 137 138
    /**
     * {@inheritdoc}
     */
139
    public function errorCode()
140 141 142 143
    {
        return db2_conn_error($this->_conn);
    }

Benjamin Morel's avatar
Benjamin Morel committed
144 145 146
    /**
     * {@inheritdoc}
     */
147
    public function errorInfo()
148 149 150 151 152 153
    {
        return array(
            0 => db2_conn_errormsg($this->_conn),
            1 => $this->errorCode(),
        );
    }
154
}